单链表输出倒数第k个结点值(栈实现)
思路1:定义两个指针变量p和q,初始时均指向头节点的下一个节点(链表的第一个节点),p指针沿链表移动;
当p指针移动到第k个节点时,q指针开始与p指针同步移动,
当p指针移动到最后一个节点时,q指针所指节点就是倒数第k个节点。 思路2:利用栈实现,遍历链表依次入栈,然后出k次栈就找到那个节点了。
1.定义栈结构
typedef struct{
int length;
int value[]; }Stack; void push(Stack &s,int v){
if(s.length <= 50){
s.value[s.length] = v;
s.length++;
printf("push: v=%d length=%d \n",v,s.length);
}else{
printf("exception: out of memory!");
return;
}
}
void pop(Stack &s,int &v){
if(s.length > 0){
v = s.value[--s.length];
printf("pop: v=%d length=%d\n",v,s.length);
}else{
printf("exception: out of memory!");
return;
}
}
void init_Stack(Stack *s){
s->length = ;
}
2.定义单链表结构
typedef struct LNode{ int data;
struct LNode *next;
}LNode,*LinkList; void init(LinkList &L){
int i;
int d;
LinkList p,r;
L = (LinkList)malloc(sizeof(LNode));
L->data = -;
L->next = NULL;
r = L;
scanf("%d",&d);
while(d != ){
p = (LinkList)malloc(sizeof(LNode));
p->data = d; //p->next = L->next;//头插法
//L->next = p;
r->next = p; //尾插法
r = p;
scanf("%d",&d);
}
r->next = NULL;//尾插法不要忘掉这个结束
} void print(LinkList L){
printf("\n");
L = L->next;
while(L!=NULL){
printf(" %d ",L->data);
L = L->next;
}
printf("\n"); }
3.实现方法
int find_munK(LinkList L, int k){
LinkList p ;
int i;
int result; Stack s;
init_Stack(&s); p = L->next;
while(p){
push(s,p->data);
p = p->next;
} for(i=;i<=k;i++){
pop(s,result); }
return result;
}
4.测试
int main(){
LinkList L1;
init(L1);
print(L1); printf("-->%d\n",find_munK(L1, )); //输出倒数第3个
return ;
}
tip:
在上面的方法中:
参数有的是普通类型:
int find_munK(LinkList L, int k)
这里的L是指针类型(因为LinkLinst是指针类型的),
k是普通类型的,进去再出来k不会被修改
有的是地址类型:
void init(LinkList &L) //这里接收的是一个地址
L是地址类型的,在方法内修改L后,出来L也被修改了
LinkList L1;//这里的LinkList是指针类型的
init(L1);
LinkNode L2;//这里的LinkNode是普通类型的
inti(*L2);
总的来说,就是传入一个地址
有的是指针类型:
void init_Stack(Stack *s)
s是指针类型的,在方法内修改后,出来s也被修改了
Stack s; //Stack就是普通类型的,和int无差,需要取地址传入指针类型的形参
init_Stack(&s);
void fun(int a,int &b,int &c,int *d,int *e){
a = ;
b = ;
c = ;
*d = ;
*e = ; }
int main(){ int a = ;
int b = ;
int * c ;
int d = ;
int * e;
c = &d;
e = &b;
printf("a=%d b=%d c=%d d=%d e=%d \n ",a,b,*c,d,*e);
fun(a,b,*c,&d,e);
printf("a=%d b=%d c=%d d=%d e=%d \n ",a,b,*c,d,*e);
}
单链表输出倒数第k个结点值(栈实现)的更多相关文章
- 查找单链表中倒数第k个结点
本文转自:程序员面试题6--查找链表中倒数第k个结点 题目:输入一个单向链表,输出该链表中倒数第k个结点.链表的倒数第0个结点为链表的尾指针.链表结点定义如下: struct ListNode { i ...
- 删除单链表的倒数第k个结点
策略 直接遍历总数为len,再次遍历第len-k+1个就是答案,但是这样遍历了O(N+k)个,可以在O在更短的时间内找到 图示 参考代码 #include <iostream> using ...
- 【编程题目】输入一个单向链表,输出该链表中倒数第 k 个结点
第 13 题(链表):题目:输入一个单向链表,输出该链表中倒数第 k 个结点.链表的倒数第 0 个结点为链表的尾指针.链表结点定义如下: struct ListNode {int m_nKey;Lis ...
- 输出单向链表中倒数第k个结点
描述 输入一个单向链表,输出该链表中倒数第k个结点,链表的倒数第0个结点为链表的尾指针. 链表结点定义如下: struct ListNode { int m_nKey; ListNode* ...
- 输入一个单向链表,输出该链表中倒数第K个结点
输入一个单向链表,输出该链表中倒数第K个结点,具体实现如下: #include <iostream> using namespace std; struct LinkNode { publ ...
- 算法:输入一个链表,输出该链表中倒数第k个结点。
算法:输入一个链表,输出该链表中倒数第k个结点.<剑指offer> 思路加到注释里面了: 1:两个if判断是否返回值为空,首个为空,没有第k个值: 2:for循环找到倒数第k个值,返回为a ...
- 【剑指offer】输入一个链表,输出该链表中倒数第k个结点。
一.题目: 输入一个链表,输出该链表中倒数第k个结点. 二.思路: 用两个指针p1和p2,p2先跑k步,然后p1和p2同时跑,p2跑到头p1所在的位置就是倒数第k个节点.很简单吧?简单你也想不到,想到 ...
- [华为]输出单向链表中倒数第k个结点
输入一个单向链表,输出该链表中倒数第k个结点,链表的倒数第1个结点为链表的尾指针. 链表结点定义如下: struct ListNode { int m_nKey; ListNode* m_ ...
- 剑指offer14:输入一个链表,输出该链表中倒数第k个结点。
1. 题目描述 输入一个链表,输出该链表中倒数第k个结点. 2. 思路和方法 可以用两个指针,一个指针遍历到第k个结点的时候,第二个指针再走到第一个节点,然后两个指针的距离始终保持k-1.这样,当第一 ...
随机推荐
- 剑指offer 面试11题
面试11题: 题目: 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素. 例如数组{3,4,5,1,2}为{1,2,3,4 ...
- 剑指offer 面试61题
面试61题: 题目:LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张^_^)...他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到 ...
- Hexo 使用中搭建博客过程中遇到的坑
本地执行hexo s 时报错: WARN No layout: index.html 原因:theme 没有下载下来,经查,theme文件夹下为空. 新建文章后,执行 hexo g 时报如下错误: ( ...
- SourceTree的基本使用---团队开发/参与开源
1.实践入门-团队开发 如果你看到第二部分关于“参与开源”的内容,而你的需求是团队开发,你会发现几个不方便的地方: 1.1.组长建项目,组员每次提交,都需要组长审查同意merge 如果你觉得麻烦,组长 ...
- 流量分析系统--zookeeper集群部署
安装zookeeper mkdir apps tar -zxvf zookeeper-3.4.5.tar.gz -C apps [root@mini1 zookeeper-3.4.5]# rm -rf ...
- AJAX实现弹窗显示详情,全选和批量删除
以Nation表为例,将Nation表显示在页面上,每一行数据前面加上复选框,后面加上查看详情,点击以弹窗形式显示每一行的数据,并且在表格最后一行加上全选复选框,点击选中全部数据,后面跟一个批量删除按 ...
- 设计模式—迭代器Iterator模式
什么是迭代器模式? 让用户通过特定的接口访问容器的数据,不需要了解容器内部的数据结构. 首先我们先模仿集合中ArrayList和LinkedList的实现.一个是基于数组的实现.一个是基于链表的实现, ...
- 【Flask】Sqlalchemy 子查询
### subquery:子查询可以让多个查询变成一个查询,只要查找一次数据库,性能相对来讲更加高效一点.不用写多个sql语句就可以实现一些复杂的查询.那么在sqlalchemy中,要实现一个子查询, ...
- get_called_class--后期静态绑定("Late Static Binding")类的名称
get_called_class--后期静态绑定("Late Static Binding")类的名称 string get_called_class ( void ) 获取静态方 ...
- 单文件夹下的C程序如何编写Makefile文件
通过学习已经学会了GCC的一些基础的命令,以及如何将C语言源代码编译成可执行文件. 我们已经知道在linux环境下编译源码时,常会有以下三个步骤: ./configure make make clea ...