一、题目


给定一个常数 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

二、解析


这题可以偷懒,倒序后先改变在数组中的位置,不用更新每一个节点的next值就能正常输出了。有坑,不一定所有节点都有效。第五个测试点不用水桶法会超时。第六个测试点需要考虑并不是所有节点都有效。用正常的思维来说,先用一个list来存储所有节点,然后二重循环遍历这个list,把乱序的整成连续的,并用另外一个list存起来。但是这样第五个测试点是超时的。

三、代码


java 超时版:

查看代码

查看代码
 package org.example.shuati;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList; public class PAT_basic_1025 {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
String[] str = br.readLine().split("\\s+");
String start = str[0];
int n = Integer.parseInt(str[1]);
int k = Integer.parseInt(str[2]);
ArrayList<Node> list = new ArrayList<>();
Node root = new Node();
for (int i = 0; i < n; i++) {
String[] s = br.readLine().split("\\s+");
Node newNode = new Node(s[0], Integer.parseInt(s[1]), s[2]);
if(s[0].equals(start))
root = newNode;
list.add(newNode);
}
Node[] lList = new Node[n];
lList[0] = root;
Node cur = root; int effectiveNode = 1; for (int i = 1; i < n; i++) {
for (Node node : list) {
if(node.address.equals(cur.next)){
lList[i] = node;
cur = node;
effectiveNode++;
break;
}
}
} for(int i=0; i<effectiveNode; i+=k){
if(i+k > effectiveNode) break;
for(int j=i,p=i+k-1; j<p; j++,p--){
Node temp = lList[j];
lList[j] = lList[p];
lList[p] = temp;
}
} for(int i=0; i<effectiveNode; i++){
if(i+1 < effectiveNode)
System.out.printf("%s %d %s\n", lList[i].address, lList[i].data, lList[i+1].address);
else
System.out.printf("%s %d -1", lList[i].address, lList[i].data);
}
}
static class Node{
private String address;
private int data;
private String next; public Node() {
} public Node(String address, int data, String next) {
this.address = address;
this.data = data;
this.next = next;
} public String getAddress() {
return address;
} public void setAddress(String address) {
this.address = address;
} public int getData() {
return data;
} public void setData(int data) {
this.data = data;
} public String getNext() {
return next;
} public void setNext(String next) {
this.next = next;
}
}
}

c++超时版,用c++改写上面的java版本仍然是超时的,将无序的输入连成一个有序的链表的二重循环花了太多时间:

查看代码

查看代码
 //
// Created by yaodong on 2023/2/18.
//
#include <vector>
#include "iostream"
using namespace std; class Node{ public:
int address,data,next;
Node(int address, int data, int next) : address(address), data(data), next(next) {}
Node() {}
};
int main(){
int initAddress, n, k;
cin>>initAddress>>n>>k;
vector<Node> vec;
Node lList[n];
Node root; int add,data,next;
for(int i=0; i<n; i++){
cin>>add>>data>>next;
Node newNode = Node(add, data, next);
if(add == initAddress)
root = newNode;
vec.push_back(newNode);
}
lList[0] = root;
Node cur = root; //有效节点,不一定所有的输入都有效
int eNode = 1;
for (int i = 1; i < n; ++i) {
for (auto item: vec){
if(item.address == cur.next){
lList[i] = item;
cur = item;
eNode++;
break;
}
}
} for(int i=0; i<eNode; i+=k){
if(i+k > eNode) break;
for(int j=i,p=i+k-1; j<p; j++,p--){
Node temp = lList[j];
lList[j] = lList[p];
lList[p] = temp;
}
} for(int i=0; i<eNode; i++){
if(i+1 < eNode)
printf("%05d %d %05d\n", lList[i].address, lList[i].data, lList[i+1].address);
else
printf("%05d %d -1", lList[i].address, lList[i].data);
}
return 0;
}

c++ AC版,用水桶法,仔细想想,水桶法也是合理的,因为实际生活中,地址位数肯定是一样的,但是题目没有说明,每一个测试用例都是5位。或许其实连这个也应该想到的。至少猜一下。

//
// Created by yaodong on 2023/2/18.
// #include "iostream"
using namespace std;
int main(){
int initAddress, n, k;
cin>>initAddress>>n>>k;
int list[100001], data[100001], next[100001];
int index;
for(int i=0; i<n; i++){
cin>>index;
cin>>data[index]>>next[index];
}
//不一定所有节点都有效
int eNode = 0;
int nextAdd = initAddress;
while(nextAdd != -1){
list[eNode++] = nextAdd;
nextAdd = next[nextAdd];
}
for(int i=0; i<eNode; i+=k){
if(i+k > eNode) break;
for(int j=i,p=i+k-1; j<p; j++,p--){
int temp = list[j];
list[j] = list[p];
list[p] = temp;
}
}
for(int i=0; i<eNode; i++){
if(i+1 < eNode)
printf("%05d %d %05d\n", list[i], data[list[i]], list[i+1]);
else
printf("%05d %d -1", list[i], data[list[i]]);
}
}

PAT-basic-1025 反转链表 java c++的更多相关文章

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

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

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

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

  3. 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→ ...

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

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

  5. 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, ...

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

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

  7. PAT Basic 1025

    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 ...

  8. 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,则输出应该 ...

  9. PAT 1025 反转链表

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

  10. 剑指Offer:面试题16——反转链表(java实现)

    问题描述 定义一个函数,输入一个链表的头结点,反转该链表并输出反转后的链表的头结点.链表结点如下: public class ListNode { int val; ListNode next = n ...

随机推荐

  1. Teamcity 部署

    1.先安装docker环境 team_city安装 2.docker run -it --name teamcity-server \ -v /data/teamctiy_data/:/data/te ...

  2. Burp学院-SQL注入

    前言: 上传下自己做的笔记,这些题做了好久好久了,一直没冒泡,之前想上传些东西结果博客园炸了就忘了,周五快下班了手头工作暂时缓解了,传点东西上来. 1.SQL injection UNION atta ...

  3. React Developer插件报错Cannot read properties of undefined (reading ‘forEach‘)

    安装了3.6的版本React Developer 启用插件后 报错 解决 https://www.crx4chrome.com/crx/3068/ 下载 下载好后,直接拖入扩展程序中

  4. 对于AF、RI、Safety from rep exposure、spec的归纳总结

    每次写实验时,在写代码之前都要进行AFRISafety from rep exposure spec的编写,过程十分繁琐,但是也非常有用.根据他们写代码,不仅可以找到切入点,而且思路更加清晰了,避免了 ...

  5. 【GENERAL FRAMEWORK】总框架——持续更新

    引: 鉴于目前挖的坑较多,未防止某些即将长期更新的博文出现烂尾,特设此框架 1.蓝桥杯(完结)         1.[蓝桥杯单片机组]LED.蜂鸣器与继电器--138-573的外设操作         ...

  6. (0828)【vivado版本-对仿真工具版本要求】

    (1)https://blog.csdn.net/Alonger1988/article/details/120506385 vivado,vsim版本兼容问题 (2)版本匹配:http://deng ...

  7. Outlook配置文件位置

    [HKEY_CURRENT_USER\Software\Microsoft\Windows NT\CurrentVersion\Windows Messaging Subsystem\Profiles ...

  8. 2023 01 19 HW

    2023 01 19 HW Okay, then let's start.  Okay. Maybe Karina, we start with the C2 design freeze. Yeah, ...

  9. android 编译 node js 14

    本文基于wsl ubuntu 22.04.1 LTS 系统 上成功编译 安卓版 node js 14.15.4的一些记录. 编译环境: nodejs 用到两套编译器分别用来编译本机的一些工具链和目标平 ...

  10. python39

    Python pass 是空语句,是为了保持程序结构的完整性. pass 不做任何事情,一般用做占位语句. Python 语言 pass 语句语法格式如下: pass 测试实例: 实例 #!/usr/ ...