c语言最大字符1025,1025 反转链表 (25 分)C语言

题目描述

给定一个常数K以及一个单链表L,请编写程序将L中每K个结点反转。例如:给定L为1→2→3→4→5→6,K为3,则输出应该为

3→2→1→6→5→4;如果K为4,则输出应该为4→3→2→1→5→6,即最后不到K个元素不反转。

输入描述:

每个输入包含1个测试用例。每个测试用例第1行给出第1个结点的地址、结点总个数正整数N(<= 105)、以及正整数K(<=N),即要求反转的

子链结点的个数。结点的地址是5位非负整数,NULL地址用-1表示。

接下来有N行,每行格式为:

Address Data Next

其中Address是结点地址,Data是该结点保存的整数数据,Next是下一结点的地址。

输出描述:

对每个测试用例,顺序输出反转后的链表,其上每个结点占一行,格式与输入相同。

输入例子:

00100 6 4

00000 4 99999

00100 1 12309

68237 6 -1

33218 3 00000

99999 5 68237

12309 2 33218

输出例子:

00000 4 33218

33218 3 12309

12309 2 00100

00100 1 99999

99999 5 68237

68237 6 -1

思路

通过数组下标来表示地址,便于链接各个节点

考虑存在无效节点的情况

#include

typedef struct {

int address;//节点地址

int data; //整数数据

int next;//下一节点的地址

} Node;

int main() {

int addr, N, K;//读取首地址,节点数量,反转个数

scanf("%d %d %d", &addr, &N, &K);

Node origin[100001], sort[100001];//创建初始单链表,反转后的单链表

for (int i = 0; i < N; i++) {//读取节点

Node temp;

scanf("%d %d %d", &temp.address, &temp.data, &temp.next);

origin[temp.address] = temp;

}

for (int i = 0; i < N; i++) {//链接节点

sort[i] = origin[addr];

addr = sort[i].next;//获取下一个节点的地址

if (addr == -1) {

N = i + 1;//可能有无效的节点,需要更新链表中节点的数量

break;

}

}

for (int i = 0; i < N / K; i++) {//反转的次数

for (int j = 0; j < K / 2; j++) {//反转

Node temp;

temp = sort[j + i * K];

sort[j + i * K] = sort[K - 1 - j + i * K];//数组下标确认好

sort[K - 1 - j + i * K] = temp;

}

}

for (int i = 0; i < N; i++) {

if(i != N - 1) {

sort[i].next = sort[i+1].address;

printf("%05d %d %05d\n", sort[i].address, sort[i].data, sort[i].next);

} else {

sort[i].next = -1;

printf("%05d %d %d\n", sort[i].address, sort[i].data, sort[i].next);

}

}

return 0;

}

PAT 1025 反转链表 &lpar;25&rpar;(STL-map&plus;思路&plus;测试点分析)

1025 反转链表 (25)(25 分) 给定一个常数K以及一个单链表L,请编写程序将L中每K个结点反转.例如:给定L为1→2→3→4→5→6,K为3,则输出应该为3→2→1→6→5→4:如果K为4, ...

PAT乙级 1025&period; 反转链表 &lpar;25&rpar;

1025. 反转链表 (25) 时间限制 300 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 给定一个常数K以及一个单链表L,请 ...

PAT-乙级-1025&period; 反转链表 &lpar;25&rpar;

1025. 反转链表 (25) 时间限制 300 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 给定一个常数K以及一个单链表L,请 ...

PAT乙级真题及训练题 1025&period; 反转链表 &lpar;25&rpar;

PAT乙级真题及训练题 1025. 反转链表 (25) 感觉几个世纪没打代码了,真是坏习惯,调了两小时把反转链表调出来了,心情舒畅. 这道题的步骤 数据输入,数组纪录下一结点及储存值 创建链表并储存上 ...

PAT &lpar;Basic Level&rpar; Practise (中文)-1025&period; 反转链表 &lpar;25&rpar;

PAT (Basic Level) Practise (中文)-1025. 反转链表 (25)   http://www.patest.cn/contests/pat-b-practise/1025 ...

PAT 1025&period; 反转链表 &lpar;25&rpar;

给定一个常数K以及一个单链表L,请编写程序将L中每K个结点反转.例如:给定L为1→2→3→4→5→6,K为3,则输出应该为3→2→1→6→5→4:如果K为4,则输出应该为4→3→2→1→5→6,即最后 ...

1025 PAT Ranking &lpar;25分&rpar;

1025 PAT Ranking (25分) 1. 题目 2. 思路 设置结构体, 先对每一个local排序,再整合后排序 3. 注意点 整体排序时注意如果分数相同的情况下还要按照编号排序 4. 代码 ...

PAT Basic 反转链表 &lpar;25&rpar; &lbrack;链表&rsqb;

题目 给定⼀个常数K以及⼀个单链表L,请编写程序将L中每K个结点反转.例如:给定L为1→2→3→4→5→6,K为3,则输出应该为3→2→1→6→5→4:如果K为4,则输出应该为4→3→2→1→5→6, ...

PAT 1025 反转链表

PAT (Basic Level) Practise 1025 Github链接:https://github.com/H-BING/object-oriented/tree/master/PAT10 ...

随机推荐

见见面、聊聊天 - 5月22日晚7点Meetup,三里屯绿树旁酒吧,畅谈云技术和应用

总是邮件.QQ什么的线上聊,让我们见面吧,不怕见光死,呵呵.   我和同事会先抛砖引玉,给大家介绍一下Autodesk几款最新的云技术和解决方案,然后大家就可畅所欲言,自由交流.来自五湖四海的人,为了 ...

Leetcode&num;128 Longest Consecutive Sequence

原题地址 1. 把所有元素都塞到集合里2. 遍历所有元素,对于每个元素,如果集合里没有,就算了,如果有的话,就向左向右拓展,找到最长的连续范围,同时在每次找的时候都把找到的删掉.这样做保证了同样的连续 ...

NYOJ737

题意:给n堆石子,按照顺序排列,只能相邻两堆石子合并,求最后合并为一堆时所花费的最小代价,石子合并代价为两堆石子之和. 输入: n(石子堆数) Xi(每堆石子个数) 输出: T(最小代价) 思路:经典 ...

Linux下运行C&plus;&plus;程序出现&quot&semi;段错误&lpar;核心已转储&rpar;&quot&semi;的原因

今天写程序出现了“段错误(核心已转储)"的问题,查了一下资料,加上自己的实践,总结了以下几个方面的原因. 1.内存访问出错  这类问题的典型代表就是数组越界. 2.非法内存访问 出现这类问题 ...

Android -- 深入了解自定义属性

1,相信我们写过自定义控件的同学都会有一个疑问,自定义属性到底是怎么工作的,为什么要使用自定义属性呢,接下来结带着大家一起来学习学习,在学习这一篇的时候,可以下看看我的上一篇

WebGL或OpenGL关于模型视图投影变换的设置技巧

目录 1. 具体实例 2. 解决方案 1) Cube.html 2) Cube.js 3) 运行结果 3. 详细讲解 1) 模型变换 2) 视图变换 3) 投影变换 4) 模型视图投影矩阵 4. 存在 ...

ASP&period;NET Core 3&period;0预览版体验

目前.NET Core 3.0的版本为.NET Core 3.0 Preview 3,对应ASP.NET Core 3.0 Preview 3. ASP.NET Core 3.0 之后将不再支持.NE ...

CodeForces615A-Bulbs-模拟

水题 #include #include using namespace std; ]; int main() { scanf(&qu ...

Spring Boot features - Profiles

https://docs.spring.io/spring-boot/docs/current/reference/html/boot-features-profiles.html https://w ...

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值