PAT甲级P1074题解

代码展示了如何使用C++实现链表操作,计算节点总数并进行地址反转,适用于数据结构学习
摘要由CSDN通过智能技术生成

#include<bits/stdc++.h>
using namespace std;
const int N = 100010;
int result[N];
int datas[N];
int List[N];
int nexts[N];
int main(void)
{
    int first,n,k,temp;
    cin>>first>>n>>k;
    for(int i = 0;i<n;i++)
    {
        cin>>temp;
        cin>>datas[temp]>>nexts[temp];
    }
    int sum = 0;
    while(first !=-1)
    {
        List[sum++] = first;
        first = nexts[first];
    }
    for(int i = 0;i<sum;i++)
    {
        result[i] = List[i];
    }
    for(int i = 0;i<(sum-sum%k);i++)
    {
        result[i] = List[i / k * k + k - 1 - i%k];
    }
    for(int i = 0;i<sum-1;i++)
    {
        printf("%05d %d %05d\n",result[i],datas[result[i]],result[i+1]);
    }
    printf("%05d %d -1",result[sum-1],datas[result[sum-1]]);
    return 0;
}

通过sum来统计节点数目,并且通过 i = i/k*k+k-1-i%k来将节点的地址反转

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值