PAT (Basic Level) Practise 1025


1、 问题概述


2、 解题思路

  • 课上听了栋哥说可以把需要反转的部分从原位置拆了,再重新插入链表最尾部。感觉这样的想法很棒!
  • 大概是这样的意思

  • 然后就按这样的想法写了一下~(单向链表感觉不好操作...后来改用了双向的...)

3、 代码

#include<stdio.h>
#include<iostream>
#include<string>
using namespace std;
struct link {
int address;
int next;
int data;
struct link *nxt;//指向下一个
struct link *last;//指向上一个
};
struct link l[100100],Lk[100100];
struct link *head; int main() {
head = (struct link*)malloc(sizeof(struct link));
int n, k;
int i, j;
scanf_s("%d%d%d", &l[0].address, &n, &k); l[0].nxt = &l[n + 1];
l[n + 1].nxt = NULL; for (i = 1; i <= n; i++) {
scanf_s("%d%d%d", &l[i].address, &l[i].data, &l[i].next);
//找出第一个节点
if (l[i].address == l[0].address) {
l[i].nxt = l[0].nxt;
l[0].nxt = &l[i];
head = &l[i];
}
} //整理链表
while (head->next != -1) {
for (i = 1; i <= n; i++) {
if (l[i].address == head->next) {
l[i].nxt = head->nxt;
head->nxt = &l[i];
head = &l[i];
break;
}
}
} //重新排列链表
head = &l[0];
for (i = 0; head->nxt != NULL; i++) { //连接新链表
if (i != 0) {
Lk[i].last = &Lk[i - 1];
Lk[i - 1].nxt = &Lk[i];
} //新链表数据转移
Lk[i].address = head->address;
Lk[i].data = head->data; head = head->nxt;
} int length = i - 1;
Lk[length].nxt = &Lk[i];
Lk[i].last = &Lk[length];
Lk[i].data = i; //链表不需要反转
if (k == 1 || k > length) { head = Lk[0].nxt;
printf("%05d %d", head->address, head->data);
head = head->nxt;
while (head->nxt != NULL) {
printf(" %05d\n%05d %d", head->address, head->address, head->data);
head = head->nxt;
}
printf(" -1\n"); return 0;
} bool islength = false;
//反转
head = &Lk[length];
for (j = 1; j*k <= length; j++) {
for (i = k*j; i > k*(j - 1); i--) { //全反转
if (k == length&&!islength) {
head = head->last;
islength = true;
} //从原序列移除
Lk[i].nxt->last = Lk[i].last;
Lk[i].last->nxt = Lk[i].nxt; //插入链表尾部
Lk[i].last = head;
head->nxt->last = &Lk[i];
Lk[i].nxt = head->nxt;
head->nxt = &Lk[i]; head = &Lk[i];
}
} //剩余不用反转部分
for (i = (j - 1)*k + 1; i <= length; i++) {
Lk[i].nxt->last = Lk[i].last;
Lk[i].last->nxt = Lk[i].nxt; Lk[i].last = head;
head->nxt->last = &Lk[i];
Lk[i].nxt = head->nxt;
head->nxt = &Lk[i]; head = &Lk[i];
} //输出
head = Lk[0].nxt;
printf("%05d %d", head->address, head->data);
head = head->nxt;
while (head->nxt != NULL) {
printf(" %05d\n%05d %d", head->address, head->address, head->data);
head = head->nxt;
}
printf(" -1\n"); return 0;
}

4、 问题与解决

  • 在链接新链表的时候,最开始都连到了原链表...新链表之间没有连接起来(⊙ˍ⊙)找了很久不知道错在哪里。最后想起栋哥说不会的时候就画图,果然,才模拟新链表第一个节点的时候就发现了问题。
  • 然后根据大神提醒,手动加头尾两个边界比较不容易出错 ( ̄︶ ̄)

5、 最后

  • 其实,这代码并没有AC (⊙ˍ⊙) 有一个点超时了...

  • 大概能猜到是重新按顺序排列链表那边耗了很多时间,不过实在不会改了orz
  • 我觉得吧,对于一个全部用数组A掉上学期C语言上机的指针题以及这学期程序设计语言综合设计的指针题的人,做到这样已经很棒了(不要脸hhh)
  • 现在应该能算是勉强会用链表了吧 0 0 不过...还是好想用数组啊

  • 真的超级赞的呀~又快又好找bug

PAT 1025 反转链表的更多相关文章

  1. PAT 1025 反转链表 (25)(STL-map+思路+测试点分析)

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

  2. PAT——1025. 反转链表

    给定一个常数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,即最后 ...

  3. PAT 1025. 反转链表 (25)

    给定一个常数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,即最后 ...

  4. PAT乙级真题及训练题 1025. 反转链表 (25)

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

  5. PAT (Basic Level) Practise (中文)-1025. 反转链表 (25)

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

  6. PAT乙级 1025. 反转链表 (25)

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

  7. PAT (Basic Level) Practice (中文)1025 反转链表 (25分)

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

  8. PAT-乙级-1025. 反转链表 (25)

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

  9. PAT (Basic Level) Practice 1025 反转链表 分数 25

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

随机推荐

  1. 看 Netty 在 Dubbo 中如何应用

    目录: dubbo 的 Consumer 消费者如何使用 Netty dubbo 的 Provider 提供者如何使用 Netty 总结 前言 众所周知,国内知名框架 Dubbo 底层使用的是 Net ...

  2. AngularJS学习笔记(一)走近AngularJS

    什么是AngularJS AngularJS是一款优秀的前端JS框架,是Google多款产品之一,简称ng. ng有着诸多特性,最为核心的是:MVVM.模块化.自动化双向数据绑定.语义化标签.依赖注入 ...

  3. java文件下载以及中文乱码解决

    在客户端下载文件时替换下载文件的名称,但是当名称是中文时浏览器会出现乱码,解决代码如下: public org.springframework.http.ResponseEntity<Input ...

  4. ELK环境搭建完整说明

    ELK环境搭建完整说明 ELK:ElasticSerach.Logstash.Kibana三款产品名称的首字母集合,用于日志的搜集和搜索.简单地理解为我们可以把服务端的日志(nginx.tomcat等 ...

  5. Linux常用基本命令:uniq-去重复

    uniq命令 作用:输出或者忽略文件中的重复行 格式: uniq [option] [file|stdin] ghostwu@dev:~/linux/uniq$ cat ghostwu.txt 192 ...

  6. python学习之老男孩python全栈第九期_day009作业

    1. 写函数,检查获取传入列表或元组对象的所有奇数位索引对应的元素,并将其作为新列表返回给调用者. 答: l1 = [] def odd(li): for i in range(1,len(li),2 ...

  7. intellij idea 2016.3.5 控制台取消行数限制

    有时候我们要输出大量的信息放到控制台显示,但是多了之后就出现最上面的信息被覆盖删除, 因此就需要设置控制台的显示行数,但在idea7之后的版本中,取消了对控制台行数设置选项, 只能通过更改配置文件进行 ...

  8. 巧用css的border属性完成对图片编辑功能的性能优化

    一.需求场景: 最近闲来无事,boss提出了一个要求,研究相关代码并完成一个关于编辑图片功能的性能优化,该功能的主要界面展示如下: 通过了几分钟的短暂试用,发现就是一个简单的裁剪并保存用户选择并上传的 ...

  9. 【代码笔记】iOS-在Block中修改外部变量值的

    一,代码. - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, ...

  10. 代码操作Word时,目录自动更新的两种方法

    最近的项目中有一个功能点为:根据分析数据库并生成报告.不过不是大数据.数据挖掘之类,报告的内容.组织方式都是事先固定下来的.实现的方式为,在普通word文档中插入书签制成模板,然后程序使用OpenXM ...