模擬考試1 BestCoder Round #1 專案管理
阿新 • • 發佈:2018-12-04
考試前水一遍BC裡面最水的題目,平均一個小時一個題目= =||,看到題目後的第一個想法是用到vector,在最短路徑dijstra演算法裡面用到的,vector+結構體,果然不出所料的超時了
#include<cstdio> #include<cstring> #include<algorithm> #include<vector> #include<iostream> using namespace std; struct node { int sum; int next; }; vector <node> vec[100010]; int ans[100010]; int main() { int t; scanf("%d",&t); while(t--) { for(int i=0; i<100010; i++) vec[i].clear(); memset(ans,0,sizeof(ans)); int n,m; scanf("%d %d",&n,&m); for(int i=0; i<m; i++) { int a,b; scanf("%d %d",&a,&b); node tmp; tmp.sum=0;tmp.next=b; vec[a].push_back(tmp); tmp.next=a; vec[b].push_back(tmp); } /*for(int c=1; c<=n; c++) { for(int d=0; d<vec[c].size(); d++) { printf("%d %d %d\n",c,vec[c][d].next,vec[c][d].sum); } }*/ int q,cmd,u,v; scanf("%d",&q); for(int i=0; i<q; i++) { scanf("%d",&cmd); if(cmd==0) { scanf("%d %d",&u,&v); ans[u]+=v; for(int r=1; r<=n; r++) { for(int s=0; s<vec[r].size(); s++) { if(vec[r][s].next==u) { vec[r][s].sum+=v; } } } } else { scanf("%d",&u); int cnt=0; for(int j=0; j<vec[u].size(); j++) { cnt+=vec[u][j].sum; //cnt+=ans[u]; } printf("%d\n",cnt); } /*for(int c=1; c<=n; c++) { for(int d=0; d<vec[c].size(); d++) { printf("%d %d %d\n",c,vec[c][d].next,vec[c][d].sum); } }*/ } } return 0; }
後來看到網上的程式碼,是vector的巢狀,是啊,這樣不用查詢啊,第一次見到這樣的用法,積累一下,總歸來說就是對vector這個容器還是不夠熟悉吧
#include"stdio.h" #include"vector" #include"string.h" #define N 100100 using namespace std; vector <int>g[N]; int c[N]; int main() { int T,a,b,n,m,q,op,i; scanf("%d",&T); while(T--) { scanf("%d%d",&n,&m); for(i=0;i<=n;i++) //清空容器 g[i].clear(); while(m--) { scanf("%d%d",&a,&b); g[b].push_back(a); //輸入資料,感覺就是一個二維陣列 g[a].push_back(b); } scanf("%d",&q); memset(c,0,sizeof(c)); while(q--) { scanf("%d",&op); if(op==0) { scanf("%d%d",&a,&b); c[a]+=b; } else { int s=0; scanf("%d",&a); for(i=0;i<g[a].size();i++) //對資料的訪問也很方便 { //printf("%d %d\n",i,g[a][i]);g[a][i]返回的就是與a有連線的結點的標號,所以不用next s+=c[g[a][i]]; } printf("%d\n",s); } } } return 0; }