“福”字倒着贴,寓意“福到”。不论到底算不算民俗,本题且请你编写程序,把各种汉字倒过来输出。这里要处理的每个汉字是由一个 N × N 的网格组成的,网格中的元素或者为字符 @ 或者为空格。而倒过来的汉字所用的字符由裁判指定。
输入格式:
输入在第一行中给出倒过来的汉字所用的字符、以及网格的规模 N (不超过100的正整数),其间以 1 个空格分隔;随后 N 行,每行给出 N 个字符,或者为 @ 或者为空格。
输出格式:
输出倒置的网格,如样例所示。但是,如果这个字正过来倒过去是一样的,就先输出bu yong dao le,然后再用输入指定的字符将其输出。
输入样例 1:
$ 9
@ @@@@@
@@@ @@@
@ @ @
@@@ @@@
@@@ @@@@@
@@@ @ @ @
@@@ @@@@@
@ @ @ @
@ @@@@@
输出样例 1:
$$$KaTeX parse error: Can't use function '$' in math mode at position 3: $̲ $ $ $ $ $
$
$ $ $ $
$
$
$
$
$ $ $
$
$
$$$$$ $
输入样例 2:
& 3
@@@
@
@@@
输出样例 2:
bu yong dao le
&&&
&
&&&
#include<stdio.h>
int main()
{
int N,i,j,q;
char former[100][100];//原数组
char later[100][100];//置换后
char ch = getchar();
scanf("%d",&N);
getchar();//吃回车
for(i=0;i<N;i++)//赋初值
{
for(j=0;j<N;j++)
{
scanf("%c",&former[i][j]);
if(former[i][j]!=' ')
{
later[N-1-i][N-1-j] = ch;//顺便给置换后的数组赋值
}
else
later[N-1-i][N-1-j]=' ';
}
getchar();//吃每行末的空格
}
if(N%2)//分奇偶讨论图像是否关于原点对称
{ q=1;//奇数最中间的默认为一个相等
for(i=0;i<N/2;i++)
{
for(j=0;j<N;j++)
{
if(former[i][j]==former[N-1-i][N-1-j])
q=q+2;//相等,表示两个相等,+2
}
}
for(j=0;j<N/2;j++)
{
if(former[N/2][j]==former[N/2][N-1-j])//中间行的判断
q=q+2;
}
}
else
{ q=0;//偶数没有最中间的值
for(i=0;i<N/2;i++)
{
for(j=0;j<N;j++)
{
if(former[i][j]==former[N-1-i][N-1-j])
q=q+2;
}
}
}
if(q==N*N)//是否中心对称
printf("bu yong dao le\n");
for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
{
printf("%c",later[i][j]);
}
printf("\n");
}
}
这个是正确的代码,之前的代码自己运行看上去是对的,后来改成了,原数组不为空格,赋值给后数组,原数组为空格时,赋给后数组空格字符。
此处引出我的问题
字符数组没赋初值的ASCII码为多少,
空格为多少,是否和NULL相等
#include<stdio.h>
int main()
{
int b;
int a[10];
char c[5];
printf("%d ",a[0]);
printf("%d ",a[3]);
printf("%d ",c[0]) ;
printf("%d ",b);
printf("%d ",' ');
}
结果为-1 0 0 0 32
字符数组没赋初值的码为0——NULL;
空格为32;
虽然显示都一样但是本质不一样,以后再题目中要注意。