您的位置:首页 > 其它

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

2014-09-03 11:58 260 查看
题目地址:点击打开链接



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
*/
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: