思路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个结点值(栈实现)的更多相关文章

  1. 查找单链表中倒数第k个结点

    本文转自:程序员面试题6--查找链表中倒数第k个结点 题目:输入一个单向链表,输出该链表中倒数第k个结点.链表的倒数第0个结点为链表的尾指针.链表结点定义如下: struct ListNode { i ...

  2. 删除单链表的倒数第k个结点

    策略 直接遍历总数为len,再次遍历第len-k+1个就是答案,但是这样遍历了O(N+k)个,可以在O在更短的时间内找到 图示 参考代码 #include <iostream> using ...

  3. 【编程题目】输入一个单向链表,输出该链表中倒数第 k 个结点

    第 13 题(链表):题目:输入一个单向链表,输出该链表中倒数第 k 个结点.链表的倒数第 0 个结点为链表的尾指针.链表结点定义如下: struct ListNode {int m_nKey;Lis ...

  4. 输出单向链表中倒数第k个结点

    描述 输入一个单向链表,输出该链表中倒数第k个结点,链表的倒数第0个结点为链表的尾指针. 链表结点定义如下: struct ListNode { int       m_nKey; ListNode* ...

  5. 输入一个单向链表,输出该链表中倒数第K个结点

    输入一个单向链表,输出该链表中倒数第K个结点,具体实现如下: #include <iostream> using namespace std; struct LinkNode { publ ...

  6. 算法:输入一个链表,输出该链表中倒数第k个结点。

    算法:输入一个链表,输出该链表中倒数第k个结点.<剑指offer> 思路加到注释里面了: 1:两个if判断是否返回值为空,首个为空,没有第k个值: 2:for循环找到倒数第k个值,返回为a ...

  7. 【剑指offer】输入一个链表,输出该链表中倒数第k个结点。

    一.题目: 输入一个链表,输出该链表中倒数第k个结点. 二.思路: 用两个指针p1和p2,p2先跑k步,然后p1和p2同时跑,p2跑到头p1所在的位置就是倒数第k个节点.很简单吧?简单你也想不到,想到 ...

  8. [华为]输出单向链表中倒数第k个结点

    输入一个单向链表,输出该链表中倒数第k个结点,链表的倒数第1个结点为链表的尾指针. 链表结点定义如下: struct ListNode { int       m_nKey; ListNode* m_ ...

  9. 剑指offer14:输入一个链表,输出该链表中倒数第k个结点。

    1. 题目描述 输入一个链表,输出该链表中倒数第k个结点. 2. 思路和方法 可以用两个指针,一个指针遍历到第k个结点的时候,第二个指针再走到第一个节点,然后两个指针的距离始终保持k-1.这样,当第一 ...

随机推荐

  1. WebService中WSDL和WADL(转)

    转自https://blog.csdn.net/liuxiao723846/article/details/51611183#commentBox 自己加了修改批注方便自己理解. 1.Java开发We ...

  2. 从SignalTap II中获取“最真实”的仿真测试向量(ZZ)

         在实际工作中,经常会遇到这样的情况:在硬件调试中采用SignalTap II反复多次编译并最终捕获到问题的原因时,才会发现,原来这个问题是逻辑问题,是可以在仿真环境下发现并快速解决的.先前没 ...

  3. Manacher专题

    1.POJ 3974 Palindrome 题意:求一个长字符串的最长回文子串. 思路:Manacher模板. #include<iostream> #include<algorit ...

  4. vue框架(一)

    一.介绍 1.Vue是什么? Vue.js (读音 /vjuː/,类似于 view) 是一套构建用户界面的渐进式框架.与其他重量级框架不同的是,Vue 采用自底向上增量开发的设计.Vue 的核心库只关 ...

  5. 01 Spring框架 基本介绍

    相信学习java,并且走Web道路的道友都应该知道Spring的大名,它的地位相信也不需要我在这里多说什么,接下来的文章就Spring的配置和使用来进行一些讲解. 首先学习框架我们都要考虑和做到以下几 ...

  6. windows下docker toolbox无法下载boot2docker.iso

    GitHub连不上导致自动更新失败.(网络形势严峻!) 通过别的途径手动下载了指定的最新的boot2docker.iso文件.(比方说迅雷!比方说迅雷!比方说迅雷!) https://github.c ...

  7. Apache NiFi 开发 安装说明

    系统环境: vmware安装的centos6.7虚拟机 jdk1.8版本 maven库3.3.9版本(在使用源码编译启动的时候需要修改配置文件与当前使用的maven版本匹配,最低使用版本好像是3.1. ...

  8. P4340 [SHOI2016]随机序列

    题目 P4340 [SHOI2016]随机序列 思维好题 做法 是否觉得水在于你是否发现加减是会抵消的,所以我们只用考虑乘的部分 一块乘只能前面无号(也就是前缀形式)才统计,所以用线段树维护区间前缀乘 ...

  9. java验证类ValidUtils

    ValidUtils.java package com.lyqc.utils; import org.apache.commons.lang.StringUtils; public class Val ...

  10. Linux文件系统及文件储存方式【转】

    本文转载自:https://blog.csdn.net/qyp199312/article/details/54927843 前言 Linux文件系统构成 文件式的文件结构 Linux的一个具体文件 ...