TOJ_1001解题报告


排版题.输出排列成菱形的字母


Problem

输入N值,编程输出如下图形。

Input

一个整数N(1<=N<=7)。

Output

排列成菱形的大写字符,首字符为Z,以后依次为Y,X...

Sample Input

3
                

Sample Output

    Z
                Y   X
                W       V
                U   T
                S
                

=============================================
分析:
         我初步的思路:因为要输出的菱形是上下对称的,因此只需要考虑图形的上半部分,并且将上半部分中特殊的第一行和中间的一行单独考虑,其他行一起考虑。

代码如下:
         
//
1001.cpp
/
#include  < stdio.h >
char  c = ' Z ' ;
int  n;

void  printLineOne( int  t)
{
    
int i;
    
for(i=1;i<=(t-1)*2;i++)
        printf(
" ");
    printf(
"%c/n",c);
    c
=c-1;
}


void  printMiddleLine( int  t)
{
    
int i;
    printf(
"%c",c);
    c
=c-1;
    
for(i=1;i<=t*4-5;i++)
        printf(
" ");
    printf(
"%c/n",c);
    c
=c-1;
}


void  printOtherLine( int  t)
{
    
int i;
    
for(i=1;i<=(n-t)*2;i++)
        printf(
" ");
    printf(
"%c",c);
    c
=c-1;
    
for(i=1;i<=t*4-5;i++)
        printf(
" ");
    printf(
"%c/n",c);
    c
=c-1;
}


int  main()
{
    
int i;
    scanf(
"%d",&n);
    
if(n==1)
    
{
        printf(
"Z/n");
    }

    
else
    
{
        printLineOne(n);
        
for(i=2;i<=n-1;i++)
        
{
            printOtherLine(i);
        }

        printMiddleLine(n);
        
for(i=n-1;i>1;i--)
        
{
            printOtherLine(i);    
        }

        printLineOne(n);
    }

    
return 0;
}



再仔细分析各行的特点之后,发现其实不用把第一行和中间行独立出来,而是可以综合各行一起考虑的。

代码如下:
   
//
////1001.cpp
/

#include  < stdio.h >

char  ch = ' Z ' ;
int  n;

void  printLine( int  t)
{
    
int i;
    
for(i=1;i<=(n-t)*2;i++)
    
{
        printf(
" ");
    }

    printf(
"%c",ch);
    ch
=ch-1;
    
if(t==1)
    
{
        printf(
"/n");
        
return;
    }

    
else
    
{
        
for(i=1;i<=t*4-5;i++)
        
{
            printf(
" ");
        }

        printf(
"%c/n",ch);
        ch
=ch-1;
    }

}



int  main()
{
    scanf(
"%d",&n);
    
int i;
    
if(n==1)
    
{
        printf(
"Z/n");
    }

    
else
    
{
        
for(i=1;i<=n;i++)
        
{
            printLine(i);
        }

        
for(i=n-1;i>=1;i--)
        
{
            printLine(i);
        }

    }

    
return 0;
}
心得:此题最烦的地方是输出的格式,一定要注意看清楚题目给的Sample的格式要求,另外就是对行与行之间异同点的分析。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值