题解 | #输出单向链表中倒数第k个结点#

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

https://www.nowcoder.com/practice/54404a78aec1435a81150f15f899417d

#include <iostream>
using namespace std;

struct ListNode {
    int value;
    ListNode* next;
};

int main() {
    int n, value, k;
    while (cin >> n) {
        // 构建列表
        auto head = new ListNode();
        ListNode* pre = head;
        while (n--) {
            auto newNode = new ListNode();
            cin >> newNode->value;
            pre -> next = newNode;
            pre = pre -> next;
        }

        cin >> k;
        pre = head;
        ListNode* res = head;
        while (k--) {
            pre = pre -> next;
        }
        while (pre != nullptr) {
            pre = pre -> next;
            res = res -> next;
        }
        cout << res -> value << endl;
    }


    return 0;
}
// 64 位输出请用 printf("%lld")

本题的考点在于:

1、如何穿件链表的数据结构。

2、如何构建链表(尤其是构建是的指针的情况)。

3、如何寻找链表的倒数K个元素。

全部评论

相关推荐

10-09 00:50
已编辑
长江大学 算法工程师
不期而遇的夏天:1.同学你面试评价不错,概率很大,请耐心等待;2.你的排名比较靠前,不要担心,耐心等待;3.问题不大,正在审批,不要着急签其他公司,等等我们!4.预计9月中下旬,安心过节;5.下周会有结果,请耐心等待下;6.可能国庆节前后,一有结果我马上通知你;7.预计10月中旬,再坚持一下;8.正在走流程,就这两天了;9.同学,结果我也不知道,你如果查到了也告诉我一声;10.同学你出线不明朗,建议签其他公司保底!11.同学你找了哪些公司,我也在找工作。
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务