PAT 1025 反转链表
PAT (Basic Level) Practise 1025
1、 问题概述
- 链接:https://www.patest.cn/contests/pat-b-practise/1025
- 概述: 给定一个常数K以及一个单链表L,将L中每K个结点反转。最后不到K个元素不反转。
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 反转链表的更多相关文章
- 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, ...
- 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,即最后 ...
- 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,即最后 ...
- PAT乙级真题及训练题 1025. 反转链表 (25)
PAT乙级真题及训练题 1025. 反转链表 (25) 感觉几个世纪没打代码了,真是坏习惯,调了两小时把反转链表调出来了,心情舒畅. 这道题的步骤 数据输入,数组纪录下一结点及储存值 创建链表并储存上 ...
- PAT (Basic Level) Practise (中文)-1025. 反转链表 (25)
PAT (Basic Level) Practise (中文)-1025. 反转链表 (25) http://www.patest.cn/contests/pat-b-practise/1025 ...
- PAT乙级 1025. 反转链表 (25)
1025. 反转链表 (25) 时间限制 300 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 给定一个常数K以及一个单链表L,请 ...
- 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→ ...
- PAT-乙级-1025. 反转链表 (25)
1025. 反转链表 (25) 时间限制 300 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 给定一个常数K以及一个单链表L,请 ...
- 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,则输出应该 ...
随机推荐
- ASP.NET MVC5+EF6+LayUI实战教程,通用后台管理系统框架(1)
文章转自:http://www.xuboyi.com/298.html 前言 网站运营有一段时间了,记录的内容都是杂七杂八的,思前想后,决定给大家分享一套ASP.Net的系列教程.手把手的做一套通用后 ...
- postgersql服务启动不了 FATAL: the database system is starting up
公司装有postgersql的数据库的服务器意外宕机,重启后数据库启动不了了,系统是windows 软件版本10,在网上找了解决方案 参考这篇文章https://blog.csdn.net/baidu ...
- 邂逅jQuery
jQuery是一个流行的JavaScript库,提供了HTML操作,CSS操作,事件,动画,Ajax和常用插件,极大地简化了JavaScript的开发. 可以从jquery.com下载jQuery库, ...
- Dev-FAT-UAT-PRO
DEV Development environment FAT Feature Acceptance Test environment UAT User Acceptance Test environ ...
- 并发编程之 Fork-Join 分而治之框架
前言 "分而治之" 一直是一个有效的处理大量数据的方法.著名的 MapReduce 也是采取了分而治之的思想.简单来说,就是如果你要处理1000个数据,但是你并不具备处理1000个 ...
- 详解contextConfigLocation|Spring启动过程详解
spring的应用初始化流程一直没有搞明白,刚刚又碰到了相关的问题.决定得好好看看这个流程.我们在开发spring的项目当中基本上都会在web.xml通过: <context-param> ...
- Mysql密码忘记了怎么办?
停止mysql: sudo /etc/init.d/MySQL stop(可能有其它的方法,总之停止MySQLd的运行就可以了) 修改mysql的配置文件: 在/etc/mysql/mysql.con ...
- Java基础——TreeSet
TreeSet是SortedSet接口的实现类,Sorted的英文意思是分类的:选择的. TreeSet可以确保集合元素处于排序状态.与HashSet集合相比,TreeSet还提供了如下几个额外方法: ...
- java图片压缩(Thumbnails)
package com.hzxc.groupactivity.server.util; import java.awt.image.BufferedImage; import java.io.*; i ...
- 哈密顿绕行世界问题(hdu2181)
哈密顿绕行世界问题 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...