Problem C X图案打印
题目描述
请编程序实现:输入一个不大于13的正整数n和一个大写字母ch,输出以字母ch为中心,边长为n的X形图案。其中,若从上往下看,在X图案4条边上的字母都是依次递增的。
在此,认为大写字母'A'-'Z'按顺序构成了一个环形结构,即'Z'与'A'是相邻的。如果n>13,或n<=0,或输入字母不为大写字母,则输出“Input Data Error.”并结束程序。
输入
一个整数n和一个大写字母ch(输入时数字和字母中间允许有空格)
输出
对应的X形图案
样例输入
4X
样例输出
(图中.表示空格) U.....U //第一层 .V...V. ..W.W.. ...X... //第二层 ..Y.Y.. //第三层 .Z...Z. A.....A
首先这一道题算是这五道题中最难的了,考场上紧张的环境下不一定可以想的出来,可以先放一放。
本题题眼:对角线输出字符,其余输出空格; 输入时数字和字母中间允许有空格;有了B题的思路,判断字母临界闭环也许不是那么困难;n与图形边长的关系为:边长 == 2*n-1;
看题解
#include<stdio.h>
int up(char ch,int n,int i);
int down(char ch,int n,int i);
int i,j,n;
char ch;
int main(){
scanf("%d %c",&n,&ch);
if(n>13 || n<=0 || ch <'A' || ch >'Z')
printf("Input Data Error."); //注意看题这里要判断
else{
for(i=1;i<=n-1;i++){
for(j=1;j<=2*n-1;j++){
if(i == j || i+j == 2*n)
printf("%c",up(ch,n,i));
else printf(" ");
}printf("\n");
}
for(j=1;j<=n-1;j++)
printf(" ");
printf("%c",ch);
for(j=1;j<=n-1;j++)
printf(" ");
printf("\n");
for(i=n+1;i<=2*n-1;i++){
for(j=1;j<=2*n-1;j++){
if(i == j || i+j == 2*n)
printf("%c",down(ch,n,i));
else printf(" ");
}printf("\n");
}
}
}
int up(char ch,int n,int i){ //以n作为中心字母
char sh; //它以上依次递减
sh=ch-(n-i);
if(sh<'A'){
sh='Z'-('A'-sh-1); //判断临界时用数轴算距离的方式好想一些
}
return sh;
}
int down(char ch,int n,int i){
char sh;
sh=ch+(i-n);
if(sh>'Z'){
sh=sh-'Z'-1+'A';
}
return sh;
}
本题思考方向:
1.把图形分为三层来算
2.找出输出字符与输出空格的区别(根据i、j、n等变量找规律)
3.学会26个字母闭环输出
此题在写时的几个脑残问题:
1.叕把if(i == j)写成if(i = j)这个特别容易错,尤其一段代码中的第一个判断语句,幸好这次发现得早,还没有编译。
2.void函数是没有返回值的,只要这个函数最后得 return 一个值都得用int型函数。
3.第一层与第二层一开始没有加换行符,换行符这个东西有时会引起格式错误,要小心。本题是一行就要用一次换行符,所以每一个新的 i 就要用一次换行符。