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 m= sqrt((double) (N + 1) / 2);

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

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

printf(" ");

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

printf("%c", c);

putchar('\m');

 }

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

{

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

 printf(" ");

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

 printf("%c", c);

 putchar('\n');

 }

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

return 0;

}

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

遇到的问题:编译错误

 

 

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

 

转载于:https://www.cnblogs.com/1793979463hyx/p/10409895.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值