输出字符回形阵

【题】

输出字符回形阵


输入图形行数N和中心字符,输出如图所示回形方阵。
例如,输入:5 Z
输出如下图形:
X  X  X  X  X
X  Y  Y  Y  X  
X  Y  Z  Y  X
X  Y  Y  Y  X
X  X  X  X  X

注:N<24,且N是奇数。


  测试输入关于“测试输入”的帮助 期待的输出关于“期待的输出”的帮助 时间限制关于“时间限制”的帮助 内存限制关于“内存限制”的帮助 额外进程关于“{$a} 个额外进程”的帮助
测试用例 1 以文本方式显示
  1. 5 Z↵
以文本方式显示
  1. X X X X X↵
  2. X Y Y Y X↵
  3. X Y Z Y X↵
  4. X Y Y Y X↵
  5. X X X X X↵
无限制 64M 0
测试用例 2 以文本方式显示
  1. 3 a↵
以文本方式显示
  1. z z z↵
  2. z a z↵
  3. z z z↵
无限制 64M 0
测试用例 3 以文本方式显示
  1. 2 b↵
以文本方式显示
  1. 2 is not a odd number!↵
无限制 64M 0

【代码】

#include <stdio.h>

#define N 100

void Output(char arr[][N],int n);
void Init(char arr[][N], int n);
void Func(char arr[][N], int n, char ch);

int main( )
{
    int n;
    char ch, arr[N][N];
	scanf("%d", &n);
	getchar();
	ch = getchar();
	//putchar(ch);

    if(n % 2 == 0)
    {
        printf("%d is not a odd number!\n", n);
        return 0;
    }

    Init(arr, n);
	//Output(arr, n);
    Func(arr, n, ch);
    Output(arr, n);
	return 0;
}

void Func(char arr[][N], int n, char ch)
{
    int i, j;
    char tmpCh;
    for(i = 0; i <= n / 2; i++)
	{
	    if(ch >= 'A' && ch <= 'Z')
            tmpCh = (ch - 'A' - (n/2-i) + 26*(n/2/26+ 1)) % 26 + 'A';
        else
            tmpCh = (ch - 'a' - (n/2-i) + 26*(n/2/26+ 1)) % 26 + 'a';
	    for(j = 0; j < n; j++)          //上侧
            if(arr[i][j] == '\0')
                arr[i][j] = tmpCh;
        for(j = 0; j < n; j++)          //右侧
            if(arr[j][n-1-i] == '\0')
                arr[j][n-1-i] = tmpCh;
        for(j = 0; j < n; j++)          //左侧
            if(arr[j][i] == '\0')
                arr[j][i] = tmpCh;
        for(j = 0; j < n; j++)          //下侧
            if(arr[n-1-i][j] == '\0')
                arr[n-1-i][j] = tmpCh;
	}
}
void Init(char arr[][N], int n)
{
    int i, j;
    for(i = 0; i < n; i++)
	{
	    for(j = 0; j < n; j++)
            arr[i][j] = '\0';
	}
}

void Output(char arr[][N], int n)
{
    int i, j;
    for(i = 0; i < n; i++)
	{
	    for(j = 0; j < n-1; j++)
            printf("%c ", arr[i][j]);
        printf("%c\n", arr[i][j]);
	}
}



  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值