解题思路:
1. 先看每个子链,是个对称的图形,可以用一个 for 循环将其打印出:
for(int j=0; j<a; j++) if(j==i || j==a-i-1) cout<<"X"; else cout<<" ";
2. 然后除了第一个子链的第一行打印之外,其后的各子链都不打印第一行,可以用一个标记变量进行标记:
bool flag=true; while(b--) for(int i=0; i<a; i++) if(i!=0 || flag) { for(int j=0; j<a; j++) if(j==i || j==a-i-1) cout<<"X"; else cout<<" "; cout<<endl; flag=false; }
注意事项:
1. 除了第一个子链的第一行打印之外,其后的各子链都不打印第一行
2. 两个DNA之间要打印一行空行
参考代码:
#include<iostream> using namespace std; int main() { int n,a,b; cin>>n; while(n--) { cin>>a>>b; bool flag=true; while(b--) for(int i=0; i<a; i++) if(i!=0 || flag) { for(int j=0; j<a; j++) if(j==i || j==a-i-1) cout<<"X"; else cout<<" "; cout<<endl; flag=false; } if(n!=0) cout<<endl; } return 0; }
0.0分
12 人评分
WU-复数求和 (C++代码)浏览:2015 |
【矩阵】 (C++代码)浏览:950 |
【计算两点间的距离】 (C语言代码)浏览:1494 |
DNA (C语言代码)浏览:540 |
1011题解浏览:766 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:547 |
C语言程序设计教程(第三版)课后习题5.5 (C语言代码)浏览:559 |
矩阵乘方 (C语言代码)浏览:1031 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:408 |
2003年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:683 |