题解 | #输出单向链表中倒数第k个结点#
输出单向链表中倒数第k个结点
http://www.nowcoder.com/practice/54404a78aec1435a81150f15f899417d
链表
#include <stdio.h>
#include <string.h>
typedef struct ListNode {
    int m_nKey;
    struct ListNode* m_pNext;
} ListNode;
int main(void) {
    int n, k;
    int num[1001] = {0};
    while (scanf("%d", &n) != EOF) {
        ListNode* head = (ListNode*)malloc(sizeof(ListNode));
        ListNode* temp = head;
        for (int i = 0; i < n; ++i) {
            scanf("%d", &num[i]);
        }
        for (int j = 0; j < n; ++j) {
            ListNode* current = (ListNode*)malloc(sizeof(ListNode));
            current->m_nKey = num[j];
            current->m_pNext = NULL;
            temp->m_pNext = current;
            temp = current;
        }
        
        temp = head;
        int m = 0;
        while (temp->m_pNext) {
            temp = temp->m_pNext;
            m++;
        }
        scanf("%d", &k);
        temp = head;
        temp = temp->m_pNext;
        for (int a = 0; a < m - k; ++a) {
            temp = temp->m_pNext;
        }
        printf("%d\n", temp->m_nKey);
    }
    return 0;
}
 阿里巴巴公司氛围 652人发布
阿里巴巴公司氛围 652人发布 查看13道真题和解析
查看13道真题和解析