题意:

每k个元素反转链表,不足k个就不反转。如原链表为1→2→3→4→5→6,k=3,则反转后的链表为3→2→1→6→5→4;若k=4,则反转后的链表为4→3→2→1→5→6。

思路:

这题会比较烦,写代码前一定要现在纸上理清思路,写出关键代码,不然出了错再改来改去真的很浪费时间,要是考试的话估计心态就蹦了。本题是比较经典的“反转链表(指反转整条链表)”的升级版,但做法是一样的。我们可以把“反转”这一动作单独抽象成一个函数,然后遍历链表,每遍历k个结点(假设是pi...pj),就把pi...pj这个子链表进行反转,易错点在于每k个子链表之间该如何衔接而确保不会断链,具体看代码,我已经注释的很详细了。

注:本题是关于“链表”操作非常经典的题目,应当熟练掌握,因为这是非常非常基础的问题。另外,个人觉得有必要说一下的是,网上很多的解题报告,以及《算法笔记》里的题解,都不是真正的“反转”操作,虽然也能AC,但不利于真正掌握链表、指针的操作,有些投机取巧。要是面试写白板代码的时候写成那种样子,是要被鄙视的。

代码:

#include <cstdio>

;
struct Node{
    int data;
    int curr,next;
}LinkList[N];

//反转操作,记录新链表的头结点和尾结点
//传入时,tail==head,记得加“&”
void reverseLinkList(int& head,int& tail)
{
    //如果链表为空,或者只有一个结点,则直接返回
     || LinkList[head].next==-) return;
    ,p=head;//p为工作指针
    tail=LinkList[head].curr;
    ){
        int next=LinkList[p].next;
        )
            head=p;//如果next为空,则当前结点为最后一个结点,令其为新链表的头结点
        LinkList[p].next=pre;
        pre=p;
        p=next;
    }
}

int main()
{
    //freopen("pat.txt","r",stdin);
    int n,k,head;
    scanf("%d%d%d",&head,&n,&k);
    int curr,data,next;
    ;i<n;i++){
        scanf("%d%d%d",&curr,&data,&next);
        LinkList[curr].data=data;
        LinkList[curr].curr=curr;
        LinkList[curr].next=next;
    }
    int p=head;
    ,tail=-;
    ){
        ;
         && cnt<k){
            p=LinkList[p].next;
            cnt++;
        }
        ){
            int tmp=p;
            p=LinkList[p].next;//先更新,再截断
            LinkList[tmp].next=-;//把子链表截断
            //翻转当前含有k个结点的子链表,并分别记录其头结点和尾结点
            int tmptail=tmphead;
            reverseLinkList(tmphead,tmptail);
            ) newhead=tmphead;
            else LinkList[tail].next=tmphead;
            tail=tmptail;//更新尾结点
        }else{
            LinkList[tail].next=tmphead;//剩余不足k个结点,就把剩余部分直接链在tail后面
            p=-;//别忘了
        }
    }
    p=newhead;
    ){
        printf("%05d %d ",LinkList[p].curr,LinkList[p].data);
        ) printf("%05d\n",LinkList[p].next);
        else printf("-1\n");
        p=LinkList[p].next;
    }
    ;
}

【第一次限时AC的时候是这么做的,但这不是纯正“翻转”操作】

#include <cstdio>
#include <vector>
#include <algorithm>
using namespace std;
;
struct Node{
    int data;
    int curr,next;
}LinkList1[N],LinkList2[N];

int main()
{
    //freopen("pat.txt","r",stdin);
    int n,k,head;
    scanf("%d%d%d",&head,&n,&k);
    int curr,data,next;
    ;i<n;i++){
        scanf("%d%d%d",&curr,&data,&next);
        LinkList1[curr].data=data;
        LinkList1[curr].curr=curr;
        LinkList1[curr].next=next;
    }
    ;
    ,pre=-;
    vector<Node> temp;
    ){
        temp.push_back(LinkList1[p]);
        cnt++;
        if(cnt==k){
            reverse(temp.begin(),temp.end());
            ){
                newhead=temp[].curr;
                pre=newhead;
            }else{
                LinkList2[pre].next=temp[].curr;
                pre=temp[].curr;
            }
            ;
            <temp.size();i++){
                LinkList2[pre].data=temp[i].data;
                LinkList2[pre].curr=temp[i].curr;
                LinkList2[pre].next=temp[i+].curr;
                pre=temp[i+].curr;
            }
            LinkList2[pre].data=temp[i].data;
            LinkList2[pre].curr=temp[i].curr;
            LinkList2[pre].next=-;
            //注意别忘了重置
            cnt=;
            temp.clear();
        }
        p=LinkList1[p].next;
    }
    ){
        LinkList2[pre].next=temp[].curr;
        pre=temp[].curr;
        ;
        <temp.size();i++){
            LinkList2[pre].data=temp[i].data;
            LinkList2[pre].curr=temp[i].curr;
            LinkList2[pre].next=temp[i+].curr;
            pre=temp[i+].curr;
        }
        LinkList2[pre].data=temp[i].data;
        LinkList2[pre].curr=temp[i].curr;
        LinkList2[pre].next=-;
    }
    p=newhead;
    ){
        printf("%05d %d ",LinkList2[p].curr,LinkList2[p].data);
        ) printf("%05d\n",LinkList2[p].next);
        else printf("-1\n");
        p=LinkList2[p].next;
    }
    ;
}

1074 Reversing Linked List的更多相关文章

  1. PAT 1074 Reversing Linked List[链表][一般]

    1074 Reversing Linked List (25)(25 分) Given a constant K and a singly linked list L, you are suppose ...

  2. PAT 甲级 1074 Reversing Linked List (25 分)(链表部分逆置,结合使用双端队列和栈,其实使用vector更简单呐)

    1074 Reversing Linked List (25 分)   Given a constant K and a singly linked list L, you are supposed ...

  3. PAT 1074. Reversing Linked List (25)

    Given a constant K and a singly linked list L, you are supposed to reverse the links of every K elem ...

  4. PAT Advanced 1074 Reversing Linked List (25) [链表]

    题目 Given a constant K and a singly linked list L, you are supposed to reverse the links of every K e ...

  5. 1074. Reversing Linked List (25)

    模拟题,注意当k == 1 与 k == n时情况 #include <stdio.h> #include <string.h> #include <iostream&g ...

  6. PAT (Advanced Level) 1074. Reversing Linked List (25)

    简单题. #include<cstdio> #include<cstring> #include<cmath> #include<vector> #in ...

  7. PAT甲题题解-1074. Reversing Linked List (25)-求反向链表

    题意说的很清楚了,这种题的话,做的时候最好就是在纸上自己亲手模拟一下,清楚一下各个指针的情况, 这样写的时候就很清楚各个指针变量保存的是什么值. PS:一次AC哈哈,所以说自己动手在纸上画画还是很有好 ...

  8. PAT 1074. Reversing Linked List

    #include <cstdio> #include <cstdlib> #include <iostream> #include <unordered_ma ...

  9. 【PAT甲级】1074 Reversing Linked List (25 分)

    题意: 输入链表头结点的地址(五位的字符串)和两个正整数N和K(N<=100000,K<=N),接着输入N行数据,每行包括结点的地址,结点的数据和下一个结点的地址.输出每K个结点局部反转的 ...

随机推荐

  1. 本地测试ajax遇到的跨域问题

    浏览器console问题描述:Cross origin requests are only supported for protocol schemes: http, data, chrome, ch ...

  2. Webstorm常用快捷键备忘(Webstorm入门指南)

    WebStorm 是jetbrains公司旗下一款JavaScript 开发工具.被广大中国JS开发者誉为“Web前端开发神器”.“最强大的HTML5编辑器”.“最智能的JavaSscript IDE ...

  3. js进阶---12-10、jquery绑定事件和解绑事件是什么

    js进阶---12-10.jquery绑定事件和解绑事件是什么 一.总结 一句话总结:on和off. 1.jquery如何给元素绑定事件? on方法 22 $('#btn1').on('click', ...

  4. 关于一些对location认识的误区(转)

    转自:http://www.cnblogs.com/lidabo/p/4169396.html 1. location 的匹配顺序是“先匹配正则,再匹配普通”. 矫正: location 的匹配顺序其 ...

  5. eclipse启动Tomcat服务输入http://localhost:8080/报404解决方法

    其实如果Tomcat能够正常启动,而就算输入http://localhost:8080时出现404错误,也不会影响Tomcat作为服务器运行.通过eclipse来启动tomcat会碰到“访问http: ...

  6. Audio/Movie/Image

    Audio 1. 引入AVFoundation 库,此库用于处理音频的播放. > 使用AVAudioPlayer 播放音频,此类只能播放本地音频文件.对于流媒体(边下边播)的播放使用第三方框架实 ...

  7. postgresql recovery.conf改变需要重启吗

    之前在研究pgpoll时,发现trigger_file参数指定的文件存在后,会自动将standby节点提升为可写节点.不需要手动执行pg_ctl promote,但是这个时间一般有延迟,因为进程会定期 ...

  8. objective-c和java下解析对象类型和数组类型JSON字符串

    首先讲objective-c如何实现: 这里需要用到2个插件,一个是JSONKit,另一个是Jastor,一共包含6个文件,3个.h头文件和3个.m实现文件.在ARC的工程中如何导入不支持ARC的第三 ...

  9. 同一局域网环境下的arp欺骗和中间人攻击(mac)

    最近读了一篇有关arp欺骗和中间人攻击的文章,于是乎就想着自己实现一下,顺便验证下微信在回话劫持后的安全性. 1.本机环境 Macbook Air:OS X 10.11 El Captain 2.推荐 ...

  10. 典型的一次jQuery.validate.js 表单中的验证应用

    var validateOption = { onkeyup:false, rules:{ password:{ required:true, remote:{ url:'index.php?app= ...