PAT 1025反转链表
来源:互联网 发布:c 软件外包兼职 编辑:程序博客网 时间:2024/06/05 05:42
给定一个常数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 400000 4 9999900100 1 1230968237 6 -133218 3 0000099999 5 6823712309 2 33218输出样例:
00000 4 3321833218 3 1230912309 2 0010000100 1 9999999999 5 6823768237 6 -1
分析:
PAT里面总有一些题能把人做烦,不是因为它很难,是因为它的描述与它的测试样例不符,从而导致不得不一次次提交修改来揣测题目的意思.这题就是个典型的例子.为了写这篇博客
我浏览了很多人的博客,发现吐槽的人很多,一些人还把做这道题的心路历程都写了下来,看完之后颇有同感.
这道题需要注意几点:1.题目提供的结点可能是没有用的结点,也就是和其他结点衔接不上的结点.2.这道题我用一个struct向量和一个int向量,想通过int向量储存更新后的数据,
然后查找输出,这种做法会导致运行超时,所以利用向量的下标来表示结点地址是个可取的方法.3,利用C语言的输出可以高效的输出地址
源代码:
#include<iostream>#include<vector>using namespace std;struct node{ int address,data,next_address;};vector<node> list(100000);//初始输入的数据vector<node> new_list;//更新后的数据vector<node> result;//反转后的数据int main(){ int first,n,k; scanf("%d%d%d",&first,&n,&k); node temp; for(int i=0;i<n;i++) { scanf("%d%d%d",&temp.address,&temp.data,&temp.next_address); list[temp.address]=temp;//向量的下标和地址联系起来 } int t=first; while(t!=-1)//更新数据,首尾衔接 { new_list.push_back(list[t]); t=list[t].next_address; } int num=new_list.size();//有效结点个数 int j=k-1; while(j<num) { for(int i=j;i>j-k;i--) result.push_back(new_list[i]); j+=k; } for(int i=j-k+1;i<num;i++) result.push_back(new_list[i]); for(int i=0;i<num-1;i++) { result[i].next_address=result[i+1].address; printf("%05d %d %05d\n",result[i].address,result[i].data,result[i].next_address);//C语言的输出可以更高效地按题目要求输出 } printf("%05d %d -1\n",result[num-1].address,result[num-1].data); return 0;}
阅读全文
0 0
- pat 1025 反转链表
- PAT 1025 反转链表
- PAT 1025反转链表
- PAT 1025反转链表
- PAT 反转链表
- ZJU PAT 1025 反转链表
- 反转链表 (PAT-B-1025)
- PAT 乙等 1025 反转链表
- PAT 乙级-1025 链表反转
- PAT 1025. 反转链表*
- PAT 1025.反转链表
- PAT练习-反转链表
- pat 1025. 反转链表
- PAT B1025. 反转链表
- Pat(Basic Level)Practice--1025(反转链表)
- 【PAT】1025 反转链表(25)basic
- PAT 1025 反转链表 (25) 解题报告
- PAT(Python)-1025:反转链表(25)
- HDU 1028-Ignatius and the Princess III(经典母函数模型)
- PCL安装过程中OpenNI安装出现问题
- Oracle VM VirtualBox虚拟机移动之后无法运行
- Mysql命令大全
- cmakelist笔记:cmake-commands
- PAT 1025反转链表
- Tomcat学习总结(1)——Tomcat入门教程
- linux下安装ngix系统
- python解析xml文件——通过etree来解析xml文件
- 在Postgres里用Sequence[译]
- 【树状数组--思维】poj 2182 Lost Cows
- HDU 1028 Ignatius and the Princess III(递推或母函数)
- 好好做事
- 1、字符串最后一个单词的长度