题目地址: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 */
链表相隔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 */
模拟判题机器判分数。
需要注意几个问题:
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 */
给你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 */