想了好久都无从下手,如何求解?

请帮帮我解答疑问,这个问题我一开始用的是二维数组的方法,但是当数字过大时就爆了,想了好久都没有想出来如何解决,能否帮我看看我的程序,或者给出一个新思路

img

img

代码逻辑有点小问题,用取余来获取就不会超出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来申请空间。需要的时候就申请一块空间。这样你的数组就不会爆啦

解答如下

img


#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;
}