浙大PAT考试1073~1076(2014-3-1)

题目地址:http://pat.zju.edu.cn/contests/pat-a-practise




1073:

直接模拟就好。

代码:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#include<cmath>
const int maxn=100005;
using namespace std;

char a[maxn];
char ans[maxn];

int main()
{
    int i;
    while(cin>>a)
    {
        int len=strlen(a);
        int flag=-1;
        if(a[0]=='+')
            flag=1;

        if(flag==-1) cout<<"-";
        int tt;
        for(i=1;i<len;i++)
        {
            if(a[i]=='E')
            {
                tt=i;
                break;
            }
        }

        int e=0;
        for(i=tt+2;i<len;i++)
            e=e*10+(a[i]-'0');
        if(a[tt+1]=='-')
            e=-e;

        if(e>0)
        {
            int k=0;
            ans[k++]=a[1];
            for(i=3;i<tt;i++)
            {
                if(e==0) break;
                ans[k++]=a[i];
                e--;
            }
            if(e>0)
            {
                while(e--)
                    ans[k++]='0';
            }
            else if(i<tt)
            {
                ans[k++]='.';
                while(i<tt)
                {
                    ans[k++]=a[i++];
                }
            }
            ans[k]='\0';
            cout<<ans<<endl;
        }
        else if(e<0)
        {
            int k=0;
            ans[k++]=a[1];
            for(i=3;i<tt;i++)
                ans[k++]=a[i];
            ans[k]='\0';

            cout<<"0.";
            e=-e;
            e--;
            while(e--)
                cout<<"0";
            cout<<ans<<endl;
        }
        else
        {
            int k=0;
            ans[k++]=a[1];
            for(i=3;i<tt;i++)
                ans[k++]=a[i];
            ans[k]='\0';
            cout<<ans<<endl;
        }

    }
    return 0;
}

/*
+1.23400E-03
-1.2E+10
*/



1074:

链表相隔m就转置,因为地址是1~10^5直接用数组模拟就好。

//这就是PAT的题目,必须考虑bug!!
//给你一个链表还需要考虑有些没有链上去的。。。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#include<cmath>
const int maxn=100005;
using namespace std;

struct node
{
    int next;
    int val;
}nod[maxn],ans[maxn];

int res[maxn];
int ans1[maxn];

int main()
{
    int cur,n,k;
    int i,j;
    while(cin>>cur>>n>>k)
    {
        for(i=0;i<n;i++)
        {
            int x;
            cin>>x;
            cin>>nod[x].val>>nod[x].next;
        }

        int t=1;
        while(cur!=-1)
        {
            ans[t].next=cur;    //这时候存放的是当前地址,见注释解释一
            ans[t++].val=nod[cur].val;
            cur=nod[cur].next;
        }
        n=t-1;

        /*cout<<"****"<<endl;
        for(i=1;i<=n;i++)
        {
            cout<<ans[i].next<<" "<<ans[i].val<<endl;
        }
        cout<<"****"<<endl;*/

        for(i=1;i<=n;i++)
        {
            res[i]=ans[i].next;
            ans1[i]=ans[i].val;
        }
        i=1;
        while(i+k<=n+1)
        {
            reverse(res+i,res+i+k);  //之前还没怎么用过reverse
            reverse(ans1+i,ans1+i+k);
            i+=k;
        }

        for(i=1;i<n;i++)
            printf("%05d %d %05d\n",res[i],ans1[i],res[i+1]);
        printf("%05d %d -1\n",res[i],ans1[i]);
        /*for(i=k;i<=n;i+=k)    //有bug.....
        {
            for(j=i;j>=i-k+2;j--)
                printf("%05d %d %05d\n",ans[j].next,ans[j].val,ans[j-1].next);
            if(i==n)
                printf("%05d %d -1\n",ans[j].next,ans[j].val);
            else
                printf("%05d %d %05d\n",ans[j].next,ans[j].val,ans[i+1].next);
        }

        if(n%k)
        {
            i=n/k*k+1;
            for(j=i;j<n;j++)
                printf("%05d %d %05d\n",ans[j].next,ans[j].val,ans[j+1].next);
            printf("%05d %d -1\n",ans[j].next,ans[j].val);
        }*/
    }
    return 0;
}

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

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

00100 2 1
00100 5 200
00200 6 -1

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

解释一:执行完之后ans变为
00100 1
12309 2
33218 3
00000 4
99999 5
68237 6
*/


1075:

模拟判题机器判分数。

需要注意几个问题:

1.先按总分排序,如果总分相同则按AC题数排序,再相等则按ID升序。

2.编译不通过得0分,如果没提交或编译没通过一题不显示。

没能debug出最后一组数据,yy不出来,只有22分/25分。

代码:

#include<iostream>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<map>
const int maxn=100005;
using namespace std;

int n,m,k;

int per[10];

struct node
{
    int index;
    int a[10];
    int total;
} nod[maxn];

int cmp(node p1,node p2)
{
    int max1=0,max2=0;
    for(int i=1;i<=k;i++)
    {
        if(p1.a[i]==per[i]) max1++;
        if(p2.a[i]==per[i]) max2++;
    }
    if(p1.total>p2.total) return 1;
    else if(p1.total==p2.total&&max1>max2) return 1;
    else if(p1.total==p2.total&&max1==max2&&p1.index<p2.index) return 1;
    return 0;
}

map <int,int> mp;

int main()
{
    int i,j;
    while(cin>>n>>k>>m)
    {
        mp.clear();
        for(i=1;i<=k;i++)
            cin>>per[i];

        int pt=0,p;

        for(i=1; i<=n; i++)
        {
            nod[i].total=-1;
            for(j=1; j<=k; j++)
                nod[i].a[j]=-1;
        }
        for(i=0; i<m; i++)
        {
            int index;
            cin>>index;

            if(!mp[index])
            {
                mp[index]=++pt;
                nod[pt].index=index;
                p=pt;
            }
            else
                p=mp[index];

            cin>>j;
            int x;
            cin>>x;
            if(x==-1)
                nod[p].a[j]=max(nod[p].a[j],0);
            else
            {
                //cout<<nod[p].a[j]<<"wa"<<endl;
                if(nod[p].a[j]==-1)
                {
                    if(nod[p].total==-1)
                        nod[p].total=x;
                    else nod[p].total+=x;
                    nod[p].a[j]=x;
                }
                else
                {
                    if(nod[p].a[j]<x)
                    {
                        nod[p].total+=x-nod[p].a[j];
                        nod[p].a[j]=x;
                    }
                }
            }
            //cout<<nod[p].total<<endl;
        }
        p++;

        sort(nod+1,nod+p,cmp);

        //cout<<nod[1].total<<endl;
        printf("1 %05d %d",nod[1].index,nod[1].total);
        for(j=1; j<=k; j++)
        {
            if(nod[1].a[j]==-1)
                printf(" -");
            else
                printf(" %d",nod[1].a[j]);
        }
        printf("\n");

        int mrank=1;
        int cnt=1;
        for(i=2; i<p; i++)
        {
            if(nod[i].total==-1) break;  //没有提交过
            if(nod[i].total<nod[i-1].total)
            {
                mrank+=cnt;
                cnt=1;
            }
            else cnt++;
            printf("%d %05d %d",mrank,nod[i].index,nod[i].total);
            for(j=1; j<=k; j++)
            {
                if(nod[i].a[j]==-1)
                    printf(" -");
                else
                    printf(" %d",nod[i].a[j]);
            }
            printf("\n");
        }
    }
    return 0;
}

/*
7 4 4
25 25 25 25
2 1 -1
2 1 -1
2 1 -1
2 2 25

7 4 20
20 25 25 30
00002 2 12
00007 4 17
00005 1 19
00007 2 25
00005 1 20
00002 2 2
00005 1 15
00001 1 18
00004 3 25
00002 2 25
00005 3 22
00006 4 -1
00001 2 18
00002 1 20
00004 1 15
00002 4 18
00001 3 4
00001 4 2
00005 2 -1
00004 2 0
*/


1076:

给你n个人,编号0~n-1,接下来是0是哪几个人的粉丝,1是哪几个人的粉丝。。。。然后问你从某个人出发,k层以内可以到达的人数,bfs即可!
代码:

#include<cstdio>
#include<cmath>
#include<algorithm>
#include<iostream>
#include<cstring>
#include<string>
#include<queue>
using namespace std;

int n,l;
int visi[1005];
int mp[1005][1005];
int res[1005];
int fa[1005];

void bfs(int x)
{
    memset(visi,0,sizeof(visi));
    memset(fa,0,sizeof(fa));
    visi[x]=1;
    queue<int> mq;
    mq.push(x);

    while(!mq.empty())
    {
        int cur=mq.front();
        mq.pop();
        for(int i=1;i<=n;i++)
        {
            if(!visi[i]&&mp[cur][i])
            {
                fa[i]=fa[cur]+1;
                if(fa[i]<=l)
                {
                    visi[i]=1;
                    mq.push(i);
                }
            }
        }
    }

    int cnt=-1;
    for(int i=1;i<=n;i++)
        cnt+=visi[i];
    res[x]=cnt;
}

int main()
{
    int i,j,k;
    while(cin>>n>>l)
    {
        memset(mp,0,sizeof(mp));
        for(i=1;i<=n;i++)
        {
            cin>>k;
            for(int t1=1;t1<=k;t1++)
            {
                cin>>j;
                mp[j][i]=1;  //i是j的粉丝 
            }
        }

        for(i=1;i<=n;i++)
            bfs(i);

        int q;
        cin>>q;
        while(q--)
        {
            int tt;
            cin>>tt;
            cout<<res[tt]<<endl;
        }
    }
    return 0;
}

/*
7 3
3 2 3 4
0
2 5 6
2 3 1
2 3 4
1 4
1 5
2 2 6
*/


你可能感兴趣的:(pat)