pta编译总结1

打印沙漏 (20 分)

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

*****

 ***

  *

 ***

*****

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

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

输入格式:

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

输出格式:

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

输入样例:

19 *

输出样例:

*****

 ***

  *

 ***

*****

2

作者: 陈越

单位: 浙江大学

时间限制: 400 ms

内存限制: 64 MB

代码长度限制: 16 KB

1 打印沙漏 (20 分)

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

*****

 ***

  *

 ***

*****

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

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

输入格式:

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

输出格式:

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

输入样例:

19 *

输出样例:

*****

 ***

  *

 ***

*****

2

作者: 陈越

单位: 浙江大学

时间限制: 400 ms

内存限制: 64 MB

代码长度限制: 16 KB

编译器:共 31 种编译器可用

题目代码

#include <stdio.h>

#include <math.h>

int main(void)

{

  int N;

  char c;

  scanf("%d %c", &N,&c);

  int i=1,j;

  int n = sqrt((double) (N + 1) / 2);

  for (i = 1; i <= n; i++)

  {

    for (j = 1; j<i; j++)

      printf(" ");

    for (j = 2 * (n - i) + 1; j >= 1; j--)

      printf("%c", c);

    putchar('\n');

  }

  for (i = 1; i <= n - 1; i++)

  {

    for (j = 1; j <= n-i-1; j++)

      printf(" ");

    for (j = 1; j <= 2 * i + 1; j++)

      printf("%c", c);

    putchar('\n');

  }

  printf("%d", N - (2 * n*n - 1));

  return 0;

}

设计思路:定义变量→输入i,j→运用公式算出上层沙漏可以打印几层→运用for循环用符号打印出上层沙漏,空格,下半层沙漏→再运用公式计算输出多余符号个数

遇到的问题:编译错误

 

解决方法:百度搜索了一下公式那里

猜你喜欢

转载自www.cnblogs.com/1793979463hyx/p/10409895.html