CCF真题答案汇总(部分)
2015-09-1数据分段
给定一个整数数列,数列中连续相同的最长整数序列算成一段,问数列中共有多少段?
#include
using namespace std;
int main(){
int n,a[1000];
cin>>n;
for(int i=0;i cin>>a[i]; } int d=a[0],m=1; for(int i=1;i if(a[i]!=d){ m++; d=a[i]; } } cout< return 0; } 2015-09-2日期计算 给定一个年份y和一个整数d,问这一年的第d天是几月几日? 注意闰年的2月有29天。满足下面条件之一的是闰年: 1)年份是4的整数倍,而且不是100的整数倍; 2)年份是400的整数倍。 #include using namespace std; int main(){ int y,d,m=1; cin>>y; cin>>d; if(y%4==0&&y%100!=0||y%400==0){ int a[12]={31,29,31,30,31,30,31,31,30,31,30,31}; for(int i=0;i<12;i++){ if(d>=a[i]){ m++; d=d-a[i]; } } }else{ int a[12]={31,28,31,30,31,30,31,31,30,31,30,31}; for(int i=0;i<12;i++){ if(d>=a[i]){ m++; d=d-a[i]; } } } cout< cout< return 0; } 2015-09-3 模板生成系统 成成最近在搭建一个网站,其中一些页面的部分内容来自数据库中不同的数据记录,但是页面的基本结构是相同的。例如,对于展示用户信息的页面,当用户为Tom 时, 网页的源代码是 #include using namespace std; #include #define maxn 0x7fffffff #include #include int m,n; int main() { int i,j; string s[105]; string s1,s2,s3,s4; cin>>n>>m; getchar(); for(i=0;i getline(cin,s[i]); map for(j=0;j { int k,k1=0; cin>>s1; getchar(); getline(cin,s2); s1.insert(0,"{{ "); s1=s1+" }}"; s2.erase(0,1); s2.erase(s2.end()-1,s2.end()); v[s1]=s2; } int j1[20],j2[20],k,k1; for(i=0;i { k1=0; memset(j1,-1,sizeof(j1)); memset(j2,-1,sizeof(j2)); for(j=0;s[i][j]!=0;j++) { if(s[i][j]=='{'&&s[i][j+1]=='{') j1[k1]=j; if(s[i][j]=='}'&&s[i][j+1]=='}') j2[k1]=j+1; if(j1[k1]!=-1&&j2[k1]!=-1) k1++; } int t=0; for(j=0;j { s3=""; for(k=j1[j]+t;k<=j2[j]+t;k++) s3.insert(s3.end(),s[i][k]); if(v.count(s3)) { s[i].replace(s[i].begin()+j1[j]+t,s[i].begin()+j2[j]+1+t,v[s3]); t=t+v[s3].size()-s3.size();//注意替代后字符串的长度发生改变,t为变化的长度。 } else { s[i].replace(s[i].begin()+j1[j]+t,s[i].begin()+j2[j]+1+t,""); t=t-s3.size(); } } cout< } return 0; } 2015-09-4高速公路 某国有n个城市,为了使得城市间的交通更便利,该国国王打算在城市之间修一些高速公路,由于经费限制,国王打算第一阶段先在部分城市之间修一些单向的高速公路。 现在,大臣们帮国王拟了一个修高速公路的计划。看了计划后,国王发现,有些城市之间可以通过高速公路直接(不经过其他城市)或间接(经过一个或多个其他城市 )到达,而有的却不能。如果城市A可以通过高速公路到达城市B,而且城市B也可以通过高速公路到达城市A,则这两个城市被称为便利城市对。 #include #include #include #include #include using namespace std; const int ADJ_NUM = 50; const int SIZE = 10001; struct _graph{ int adj[ADJ_NUM]; // 来记录邻接点的下标 int num; // 指示邻接点的数目 }; _graph V[SIZE] = {0}; int LOW[SIZE] = {0}; int DFN[SIZE] = {0}; bool instack[SIZE] = {false}; // 用来记录一个顶点是否在栈里面 int Stap[SIZE] = {0}; int Belong[SIZE] = {0}; int Dindex, Stop, Bcnt; int answer = 0; void tarjan(int i) { int j; int index = 0; DFN[i] = LOW[i] = ++Dindex; // 标记 instack[i] = true; // 表示这个节点在栈里面 Stap[++Stop] = i; // 入栈 while (true) // 寻找邻节点 { j = V[i].adj[index++]; if (j == 0) break; if (!DFN[j]) // 如果该点还未有入栈 { tarjan(j); // 从这个节点开始访问,也就是递归 if (LOW[j] < LOW[i]) // j节点访问完成之后,LOW[j]可能发生了变化,要更新LOW[i] LOW[i] = LOW[j]; } else if (instack[j] && DFN[j] < LOW[i]) // 该节点已经在栈里面了 LOW[i] = DFN[j]; } if (DFN[i] == LOW[i]) // DFN[i] == LOW[i]这说明有一个强连通分量{ int sum = 0; Bcnt++; // 这里表示联通分量的数量加一 do { j = Stap[Stop--]; instack[j] = false; // 这里表示出栈 Belong[j] = Bcnt; sum++; } while (j != i); if (sum != 0) answer += (sum * (sum - 1)) / 2; } } void solve(int N) { int i; Stop = Bcnt = Dindex = 0; memset(DFN, 0, sizeof(DFN)); for (i = 1; i <= N; i++) if (!DFN[i]) tarjan(i); } int main() { int n, m; int a, b; cin >> n >> m; while (m--) { cin >> a >> b; V[a].adj[V[a].num] = b; // 从a到b有一条边 V[a].num++; // 计数器加1 } solve(n); cout << answer << endl; return 0; } 2015-09-5 暂无 2015-03-1图像旋转 旋转是图像处理的基本操作,在这个问题中,你需要将一个图像逆时针旋转90度。 计算机中的图像表示可以用一个矩阵来表示,为了旋转一个图像,只需要将对应的矩阵旋转即可。 #include using namespace std; int a[1000][1000]; int b[1000][1000]; int main(){ int m,n; cin>>m>>n; for(int i=0;i for(int j=0;j cin>>a[i][j]; } } for(int i=0;i for(int j=0;j b[n-1-j][i]=a[i][j]; } } for(int i=0;i for(int j=0;j cout< } cout< } return 0; } 2015-03-2数字排序 给定n个整数,请统计出每个整数出现的次数,按出现次数从多到少的顺序输出。 #include using namespace std; int a[1000],b[1000]; int swap(int &a,int &b) { int k; k=a; a=b; b=k; } int main() { int n,max=0,m; cin>>n; for(int i=0;i { cin>>a[i]; b[i]=1; } // 从小到大排序 for(int i=0;i { for(int j=i+1;j { if(a[i]>a[j]) swap(a[i],a[j]); }( } // 每个数出现的次数 for(int i=1;i { if(a[i]==a[i-1]) { b[i]=b[i-1]+1; b[i-1]=0; } } // for(int i=0;i { if(b[i]>max) max=b[i]; } for(int i=max;i>=1;i--) { for(int j=0;j { if(b[j]==i) { cout< } } } return 0; } 2015-03-3节日 有一类节日的日期并不是固定的,而是以“a月的第b个星期c”的形式定下来的,比如说母亲节就定为每年的五月的第二个星期日 #include using namespace std; int day[2][12]={31,28,31,30,31,30,31,31,30,31,30,31,31,29,31,30,31,30,31,31,30,31,30,31}; int year(int a) { int run=0,ping=0,s; for(int i=1850;i { if(i%400==0||i%100!=0&&i%4==0) run++; else ping++; } s=run*366+ping*365; return s; } int month(int b,int tab) { int s=0; for(int i=0;i s+=day[tab][i]; return s; } int main() { int a,b,c,y1,y2; cin>>a>>b>>c>>y1>>y2; for(int i=y1;i<=y2;i++) { int tab=0,count=0; if(i%400==0||i%100!=0&&i%4==0) tab=1; int s=year(i)+month(a,tab); int week=(s-1)%7+3; int j=0; for(j=0;j { if(week==c) { count++; if(count==b) { cout< break; } } week=week%7+1; } if(j==day[tab][a-1]) cout<<"none"< } return 0; } 2015-03-4网络延时 2014-12-1门禁系统 涛涛最近要负责图书馆的管理工作,需要记录下每天读者的到访情况。每位读者有一个编号,每条记录用读者的编号来表示。给出读者的来访记录,请问每一条记录中的读者 是第几次出现。 #include using namespace std; int main(){ int n,a[1000],b[1000]; cin>>n; for(int i=0;i cin>>a[i]; b[i]=1; } for(int i=1;i for(int j=0;j if(a[i]==a[j]){ b[i]++; } } } for(int i=0;i cout< } return 0; } 2014-12-2 Z字形扫描 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag Scan)。给定一个n ×n的矩阵,Z字形扫描的过程如下图所示: #include using namespace std; int main(){ int n,a[500][500]; cin>>n; for(int i=0;i for(int j=0;j cin>>a[i][j]; } } for(int k=0;k<2*n-1;k++){ for(int i=0;i for(int j=0;j if(i+j==k){ if(k%2==0){ cout< }else{