PTA编程总结1

题目 

7-1 打印沙漏 (20 分)

本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印

*****
 ***
  *
 ***
*****

所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。

给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。

输入格式:

输入在一行给出1个正整数N(≤1000)和一个符号,中间以空格分隔。

输出格式:

首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。

输入样例:

19 *

输出样例:

*****
 ***
  *
 ***
*****
2
1)实验代码
#include
#include
int main()
{
  int i=1,j,x,n,sum=0,k;
  char op;
  scanf("%d %c",&n,&op);
  
  x=sqrt((n+1)/2); 
  
  
  
  for(i=x;i>0;i--){  //X为最高的行数   最高行递减到最低行 
    
    for(j=i;j//  最高行无空格,递减行,依次多输出一个空格 
      printf(" ");
      
    }
    
    for(k=1;k<=2*i-1;k++){
      
      printf("%c",op);       //是第几行,就输出2n-1个符号 
      
      
    }
    
    printf("\n");
    
  }
  
  for(i=2;i<=x;i++){      //等差数列从第2行开始 
    
    for(j=1;j<=x-i;j++){ //最高行减去此行,即为此行的空格数 
      
      printf(" ");
      
    }
    for(k=1;k<=2*i-1;k++){  // 2n-1个符号 
      
      printf("%c",op);
      
    }
    
    printf("\n");
    
    }
      sum=n-(2*x*x-1);
  

  printf("%d\n",sum);
  return 0;
}

2)设计思路

 首先输入数字后确定有多少行,从最上面开始打印,先打印上半部分,每行字符数为2*对应行-1个,第一行是全为字符的,从第二行开始每行开头一次多一个空格,字符数还是2*对应行-1.下半部分也是一样的。

3) 本题调试过程碰到问题及解决办法

这段代码是参考计科四班曹泳的。

4)运行结果截图

PTA编程总结1_第1张图片

 

 


你可能感兴趣的:(PTA编程总结1)