请帮帮我解答疑问,这个问题我一开始用的是二维数组的方法,但是当数字过大时就爆了,想了好久都没有想出来如何解决,能否帮我看看我的程序,或者给出一个新思路
代码逻辑有点小问题,用取余来获取就不会超出A-Z的范围,上面题主的代码,n 过大会导致超出A-Z,n=53, m = 91-(53-26) = 64就是A的前一个字符@,超出了范围。
int main()
{
char w[1000][1000];
int i,j = 0;
int n = 0;
scanf("%d",&n);
int k = 2 * n - 1;
char x = 91 - n % 26 ;
for(i = n; i > 0; i--)
{
for(j = 0; j < k; j++)
{
w[i-1][j]=x;
w[k-i][j]=x;
w[j][i-1]=x;
w[j][k-i]=x;
}
if(x == 90)
{
x = 65;
continue;
}
x++;
}
for(i = 0; i < k; i++)
{
for(j = 0; j < k; j++)
{
printf("%c", w[i][j]);
}
printf("\n");
}
return 0;
}
#include<stdio.h>
int main(){
char w[1000][1000];
int i,j=0;
int n=0;
scanf("%d",&n);
int k=2*n-1;
char x=91-n;
char m=91-(n-26);
for(i=n;i>0;i--){
if(x<65) x=m;
for(j=0;j<k;j++){
w[i-1][j]=x;
w[k-i][j]=x;
w[j][i-1]=x;
w[j][k-i]=x;
}
if(x==90){
x=65;
continue;
}
x++;
}
for(i=0;i<k;i++){
for(j=0;j<k;j++){
printf("%c",w[i][j]);
}
printf("\n");
}
return 0;
}
题主你还可以用二维数组的方法,只不过你要通过malloc来申请空间。需要的时候就申请一块空间。这样你的数组就不会爆啦
解答如下
#include <stdio.h>
char t[1005][1005];
void out(int n)
{
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
printf("%c",t[i][j]);
}
printf("\n");
}
}
void set(int n)
{
char fir='Z';
int l=0,r=n-1,i;
while(l<r)
{
if(fir<'A') fir='Z';
for(i=l;i<=r;i++){
t[l][i]=fir;
}
for(i=l+1;i<=r;i++){
t[i][r]=fir;
}
for(i=r-1;i>=l;i--){
t[r][i]=fir;
}
for(i=r-1;i>l;i--){
t[i][l]=fir;
}
l++;
r--;
fir--;
}
if(n%2!=0)
{
t[l][l]=fir;
}
}
int main()
{
int n;
scanf("%d",&n);
set(n*2-1);
out(n*2-1);
return 0;
}