7-1 求链式线性表的倒数第K项(C语言/C++解法)(PTA)

本文介绍了如何使用C语言和C++实现链表中查找倒数第k项,包括传统链表遍历方法以及利用C++的动态数组(滑动窗口)简化代码。
摘要由CSDN通过智能技术生成

 题目描述

 求解思路

这题可以用传统的链表,也可以用数组来写(偷懒写法)

C语言解法

#include<stdio.h>
#include<stdlib.h> 
typedef struct LinkList 
{
    int data;
    struct LinkList* next;
}link;

int main() {
    //创建头结点并且初始化链表
    link* head = (link*)malloc(sizeof(link));
    head->next = NULL;

    link* cur = head; //cur节点用于追踪最后的结点完成链表插入

    int reverseTarget, number, cnt = 0; // 需要查找的倒数第k项、当前输入的数字、链表元素个数
    scanf("%d", &reverseTarget);
    scanf("%d", &number);

    // 对于每一个数 创建节点并插入链表中
    link* newNode = (link*)malloc(sizeof(link));
    newNode->data = number;
    newNode->next = NULL;

    cur->next = newNode; //cur在最开始是头结点位置 指向节点newNode实现链表链接
    cur = cur->next; //追踪最后的结点
    cnt++;

    while (number >= 0) 
    {
        scanf("%d", &number);
        if (number < 0) 
        {
            break;
        }

        link* newNode = (link*)malloc(sizeof(link));
        newNode->data = number;
        newNode->next = NULL;
        cur->next = newNode;
        cur = cur->next;
        cnt++;
    }

    // 正序在链表中查找倒数第k项
    cur = head; // cur节点重新设置为链表的头结点,为了从头开始遍历链表
    int target = cnt - reverseTarget + 1; //由于链表我们假定是从1开始的 那么相减后还要+1用实现偏移
    /*flag = cnt - target + 1  
         = 10 - 3 + 1
         = 8*/
    //1 -> 2 -> 3 -> 4 -> 5 -> 6 -> 7 ->[8] -> 9 -> 10

    int flag = 0; // 标志是否成功遍历了一次链表
    while (cur->next && target > 0) {
        flag = 1;
        cur = cur->next; // 不断向右
        target--;  //对于每一次cur移动 target-- 有多少个targer就移动多少次
        if (target == 0) // target为0 成功找到倒数第k个元素
        {
            printf("%d", cur->data);
            break;
        }
    }

    //如果while循环出来 target不是0(没找到)或flag是0(没遍历),就说明链表长度不足或空链表,输出NULL
    if (target != 0 || flag == 0) {
        printf("NULL");
    }


}

C++解法

C++利用了动态数组vector,简化了很多代码.C语言的解法也可以仿照C++,创建一个数组即可,这里不再写了

#include <bits/stdc++.h>
using namespace std;

vector<int> nums; //滑动窗口思想维持固定k个长度的数组

int main()
{
    int k,num;
    cin>>k;
    while(cin>>num && num>=0) //非负整数持续读入
    {
        nums.push_back(num);
        if(nums.size()>k)
        {
            nums.erase(nums.begin()); 
            //当数组长度大于k时,删除数组的第一个元素,以维持数组的长度k
        }
    }
    if(nums.size()<k) //如果数据长度小于k 不存在倒数第k个数 输出错误信息
    {
        cout<<"NULL"<<endl;
    }
    else
    {
        cout<<nums[0]<<endl; //此时数组的第一个元素就是倒数第k个数
    }
    return 0;
}

根据引用,C语言代码pta7-1可以实现输入一个1到7的数字,输出对应的星期名的缩写。以下是一个实现该功能的C语言代码示例: ``` #include <stdio.h> int main() { int n; char* s[] = {"Mon", "Tue", "Wed", "Thu", "Fri", "Sat", "Sun"}; printf("请输入一个数字(1-7):"); scanf("%d", &n); printf("%s\n", s[n-1]); return 0; } ``` 这段代码会提示用户输入一个1到7的数字,然后根据输入的数字输出对应的星期名的缩写。例如,输入1会输出"Mon",输入2会输出"Tue",以此类推。注意,由于数组的索引是从0开始的,所以我们需要将输入的数字减去1来得到正确的索引值。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [PTA 第五章算法题汇总](https://blog.csdn.net/billlee7942/article/details/106250002)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [PTA-MOOC《Python程序设计浙江大学》拼题题目集第五章编程题题目及代码答案](https://blog.csdn.net/weixin_45115928/article/details/104516791)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值