zoukankan      html  css  js  c++  java
  • PAT-1032

    这道题最先开始时用栈和map来做的,首先将两个链表压入栈中,然后从栈顶开始比较两个元素,发现最后一个数据超时了。

    然后用一种比较巧的方法,计算每个节点的反向链接节点数目,只要是交点,反向链接节点数目就会是2,由此计算出交集点。发现最后一个测试用例还是超时,于是网上搜罗了一下,发现网上有人用第一种方法就过了,奇怪,难道是我把整数都处理成字符串的原因?输入输出换成了cin>>,cout原因?这些细节都要注意。第一种方法写出来代码

    // 1032.cpp : 定义控制台应用程序的入口点。
    //
    
    #include "stdafx.h"
    #include<string>
    #include<iostream>
    #include<map>
    #include<stack>
    using namespace std;
    
    struct Node
    {
        char data;
        string next;
    };
    stack<string> s1;
    stack<string> s2;
    
    int main()
    {
        string start,end;
        string a;
        int n;
        map<string,Node> list;
        freopen("1032-in.txt","r",stdin);
        //freopen("1032-out.txt","w",stdout);
        while(cin>>start>>end>>n)
        {
            for(int i=0;i<n;i++)
            {
                Node node;
                cin>>a>>node.data>>node.next;
                list.insert(make_pair(a,node));//map-insert
            }
        }
        string next=start;
        while(true)
        {
            s1.push(next);
            map<string,Node>::iterator it=list.find(next); //map-find
            if(it!=list.end())
                next=it->second.next;
            else
                break;
            if(next=="-1")
                break;
        }
        next=end;
        while(true)
        {
            s2.push(next);
            map<string,Node>::iterator it=list.find(next);//map-find
            if(it!=list.end())
              next=it->second.next;
            else
                break;
            if(next=="-1")
                break;
        }
        string t1,t2;
        string pos="";
        while(true)
        {
            t1=s1.top();
            t2=s2.top();
            s1.pop();
            s2.pop();
            if(t1!=t2||s1.empty()||s2.empty())
                break;
            pos=t1;
        }
        if(!pos.empty())
            cout<<pos<<endl;
        else
            cout<<"-1"<<endl;
    
        return 0;
    }

    map.find返回迭代器,map.erase输入迭代器的位置,或者输入关键字的值。map要熟练使用

    最后用的是网上比较多人使用做标记的方法,第一次访问过的元素全部坐上标记。

    从start2开始访问,只要是交集节点,再次访问时候,标志位就为1,如此交集节点算出来了。这题目是2012年研究生入学考试题目,为嘛我一点印象都没有了。。。。。。

    // 1032.cpp : 定义控制台应用程序的入口点。
    //
    
    #include "stdafx.h"
    #include<stdio.h>
    #include<string>
    #include<iostream>
    #include<map>
    #include<stack>
    using namespace std;
    struct Node
    {
        char data;
        int next;
    }node[100010];
    
    bool flag[100010];
    
    int main()
    {
        int a,b,n;
        int s1,s2;
        char data;
        freopen("1032-in.txt","r",stdin);
        while(scanf("%d%d%d",&a,&b,&n)!=EOF)
        {
            int pos=-1;
            for(int i=0;i<n;i++)
            {
                scanf("%d %c %d",&s1,&data,&s2);
                node[s1].next=s2;
            }
            int next=a;
            while(next!=-1)
            {
                flag[next]=true;
                next=node[next].next;
            }
            next=b;
            while(next!=-1)
            {
                if(flag[next])
                {
                    pos=next;
                    break;
                }
                next=node[next].next;
            }
            if(a==b)
            {
                printf("%05d
    ",a);
                return 0;
            }
            if(pos!=-1)
              printf("%05d
    ",pos);
            else
              printf("-1
    ");
        }
        return 0;
    }

    注意有一个测试用例是,两个起始节点是一样的。

  • 相关阅读:
    朴素贝叶斯
    决策树算法
    devstack脚本安装Openstack总结(转载)
    squid重定向(python 代码)
    centos安装第三方源
    linux学习笔记之树目录和硬盘分区
    man指令
    关于hadoop学习常识
    Hadoop学习之环境搭建和解决方案
    多系统共存的一些想法
  • 原文地址:https://www.cnblogs.com/championlai/p/4083295.html
Copyright © 2011-2022 走看看