GPLT天梯赛 L2-022. 重排链表

L2-022. 重排链表

时间限制

500 ms

内存限制

65536 kB

代码长度限制

8000 B

判题程序

Standard

作者

陈越

给定一个单链表 L1→L2→...→Ln-1→Ln,请编写程序将链表重新排列为 Ln→L1→Ln-1→L2→...。例如:给定L为1→2→3→4→5→6,则输出应该为6→1→5→2→4→3。

输入格式:

每个输入包含1个测试用例。每个测试用例第1行给出第1个结点的地址和结点总个数,即正整数N (<= 105)。结点的地址是5位非负整数,NULL地址用-1表示。

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

Address Data Next

其中Address是结点地址;Data是该结点保存的数据,为不超过105的正整数;Next是下一结点的地址。题目保证给出的链表上至少有两个结点。

输出格式:

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

输入样例:

00100 6
00000 4 99999
00100 1 12309
68237 6 -1
33218 3 00000
99999 5 68237
12309 2 33218

输出样例:

68237 6 00100
00100 1 99999
99999 5 12309
12309 2 00000
00000 4 33218
33218 3 -1

不会链表的渣渣,各种STL... 模拟

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<string>
#include<map>
#include<vector>
#include<deque>
#include<algorithm>
#define MAX 100005
using namespace std;

struct rec{
    char add[10];
    int dat;
    char nex[10];
}rec[MAX];
struct Node{
    char add[10];
    int dat;
}node;
vector<Node> v[MAX];
deque<Node> q;
int main()
{
    int t,n,i;
    char add[10];
    map<string,int> mpadd;
    map<string,int> mpdat;
    scanf(" %s %d",add,&n);
    t=0;
    for(i=1;i<=n;i++){
        scanf(" %s %d %s",rec[i].add,&rec[i].dat,rec[i].nex);
        if(!mpadd[rec[i].add]) mpadd[rec[i].add]=++t;
        if(!mpdat[rec[i].add]) mpdat[rec[i].add]=rec[i].dat;
        if(!mpadd[rec[i].nex]) mpadd[rec[i].nex]=++t;
    }
    for(i=1;i<=n;i++){
        strcpy(node.add,rec[i].nex);
        node.dat=mpdat[rec[i].nex];
        v[mpadd[rec[i].add]].push_back(node);
    }
    while(strcmp(add,"-1")!=0){
        strcpy(node.add,add);
        node.dat=mpdat[add];
        q.push_back(node);
        strcpy(add,v[mpadd[add]][0].add);
    }
    int c=0;
    while(q.size()){
        c++;
        if(c==1){
            printf("%s %d",q.back().add,q.back().dat);
            q.pop_back();
        }
        else if(c&1){
            printf(" %s\n%s %d",q.back().add,q.back().add,q.back().dat);
            q.pop_back();
        }
        else{
            printf(" %s\n%s %d",q.front().add,q.front().add,q.front().dat);
            q.pop_front();
        }
    }
    printf(" -1\n");
    return 0;
}

原文地址:https://www.cnblogs.com/yzm10/p/8552494.html

时间: 2024-08-30 06:15:24

GPLT天梯赛 L2-022. 重排链表的相关文章

团体程序设计天梯赛-练习集 L2-2. 链表去重 数组模拟链表

L2-2. 链表去重 时间限制 300 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 给定一个带整数键值的单链表L,本题要求你编写程序,删除那些键值的绝对值有重复的结点.即对任意键值K,只有键值或其绝对值等于K的第一个结点可以被保留.同时,所有被删除的结点必须被保存在另外一个链表中.例如:另L为21→-15→-15→-7→15,则你必须输出去重后的链表21→-15→-7.以及被删除的链表-15→15. 输入格式: 输入第一行包含链表第一个结

PTA天梯赛L2

L2-001 紧急救援 题意:就是给你一张n<500的图:让你求最短路径,最短路条数,以及路径: 做法,先用dijkstra求最短路,然后dfs找最短路条数,以及点权的最大值: 一般dfs不就可以解决这个问题吗,像n皇后求次数,注意回溯即可: 那如何dfs确定这条路是最短路径呢?贪心思想,枚举每一个邻居,如果满足   dis[y.v]==dis[x]+y.w 说明当前邻居 通过这个点可以一直是最短路径,这样dfs下去,如果碰到d就return掉: 主要是没有想到用dfs求最短路径条数,然后注意回

PAT 团体程序设计天梯赛-练习集 题解(凑零钱,堆栈,社交集群)

开始准备cccc(cry)天梯赛了,第一周训练题,把官网挂出的训练题刷完了,对pat有了一点点的熟悉感. L1-1  就不说了... L1-2 打印沙漏 一个变量保存空格数,一个变量保存沙漏符号数,打印就行了,但这题话说wrong好几次啊,坑点是沙漏符号后面不打印空格,orz... <span style="font-size:14px;">#include<iostream> #include<stdio.h> #include<math.h

PAT 团体程序设计天梯赛-练习集L1-011. A-B

本题要求你计算A-B.不过麻烦的是,A和B都是字符串 —— 即从字符串A中把字符串B所包含的字符全删掉,剩下的字符组成的就是字符串A-B. 输入格式: 输入在2行中先后给出字符串A和B.两字符串的长度都不超过104,并且保证每个字符串都是由可见的ASCII码和空白字符组成,最后以换行符结束. 输出格式: 在一行中打印出A-B的结果字符串. 输入样例: I love GPLT! It's a fun game! aeiou 输出样例: I lv GPLT! It's fn gm! 1 #inclu

99. 重排链表

99. 重排链表 难度系数 中等 通过率 24% 描述 笔记 数据 评测 给定一个单链表L: L0→L1→-→Ln-1→Ln, 重新排列后为:L0→Ln→L1→Ln-1→L2→Ln-2→- 必须在不改变节点值的情况下进行原地操作. 您在真实的面试中是否遇到过这个题? Yes 样例 给出链表 1->2->3->4->null,重新排列后为1->4->2->3->null /** * Definition of ListNode * class ListNode

天梯赛+蓝桥杯 总结

3月31天梯赛,4.1蓝桥杯.两个比赛接着好近,而且都是第一次参赛,有点小紧张的. 天梯赛个人打的一般般,凉凉了. 蓝桥杯的话就更凉了,感觉比以前的题目难多了. 先说天梯赛吧,比赛时好多人都出现了账号名字与真实姓名不同的情况下,或者登入不进去,还好我的登入成功了.由于这个问题比赛推迟了十分钟,还好没推迟很久. 进去后首先就看了第一题20分的,看了三分钟左右,还没有看懂题意,心理就感觉要凉了,第一题都还没看懂.之后才知道第一题是L1中最难的.... 还好卡了就没有继续钻牛角尖了,直接返回看分值最小

Leetcode 143.重排链表

重排链表 给定一个单链表 L:L0→L1→-→Ln-1→Ln ,将其重新排列后变为: L0→Ln→L1→Ln-1→L2→Ln-2→- 你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换. 示例 1: 给定链表 1->2->3->4, 重新排列为 1->4->2->3. 示例 2: 给定链表 1->2->3->4->5, 重新排列为 1->5->2->4->3. 1 public class Solution{ 2

PTA|团体程序设计天梯赛-练习题目题解锦集(C/C++)(持续更新中……)

PTA|团体程序设计天梯赛-练习题目题解锦集(持续更新中) 实现语言:C/C++:      欢迎各位看官交流讨论.指导题解错误:或者分享更快的方法!! 题目链接:https://pintia.cn/problem-sets/994805046380707840/problems 目录 (点击对应题目即可进入相应题解--小声BB--) L1-001 Hello World (5 分) L1-002 打印沙漏 (20 分) L1-003 个位数统计 (15 分) L1-004 计算摄氏温度 (5

第四届cccc团体程序设计天梯赛

蒟蒻的第一次参加天梯赛,也能也是最后一次参加天梯赛了,下半年打完icpc就要退役了,准备考研复习了 本人的第一次天梯赛,也是本校的第一次天梯赛,由于大家都缺少经验,痛失银奖,只拿了个铜奖回来(刚开始银牌区第二的,比赛结束变成铜牌第二了,哭唧唧),下次打应该会少踩写坑. 这届次的L1-8是“罪魁祸首”,我们几个队友头铁一直去莽这道题(我也花了不少时间),直到主办人员过来说进阶标准降到600分,我才写L2的,然后L2-4用stack写又出bug了,改了半天改不出来,浪费了 几十分钟,最后受不了了,直