-
题目描述:
-
输入一个链表,输出该链表中倒数第k个结点。
(hint: 请务必使用链表。)
-
输入:
-
输入可能包含多个测试样例,输入以EOF结束。
对于每个测试案例,输入的第一行为两个整数n和k(0<=n<=1000, 0<=k<=1000):n代表将要输入的链表元素的个数,k代表要查询倒数第几个的元素。
输入的第二行包括n个数t(1<=t<=1000000):代表链表中的元素。
-
输出:
-
对应每个测试案例,
若有结果,输出相应的查找结果。否则,输出NULL。
-
样例输入:
-
5 2 1 2 3 4 5 1 0 5
-
样例输出:
-
4 NULL
-
//双向链表 #include<stdio.h> #include<stdlib.h> typedef struct Lnode { int data; struct Lnode *prior; struct Lnode *next; }Lnode,*Link; int main() { int n,m,i; while(scanf("%d%d",&n,&m)!=EOF) { Link la,pa,p; la=(Link)malloc(sizeof(Lnode)); la->prior = la->next = NULL; pa=la; for(i=0;i<n;i++) { p=(Link)malloc(sizeof(Lnode)); scanf("%d",& p->data); p->next = pa->next; p->prior = pa; pa->next = p; pa=p; } if(!pa || m<=0 || m>n) printf("NULL\n"); else { for(i=1;i<m;i++) { p=pa; pa=pa->prior; free(p); } printf("%d\n",pa->data); } while(pa) { p=pa; pa=pa->prior; free(p); } } return 0; }