博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
打印沙漏
阅读量:6902 次
发布时间:2019-06-27

本文共 962 字,大约阅读时间需要 3 分钟。

7-1 打印沙漏 (20 分)

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





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

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

输入格式:

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

输出格式:

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

include<stdio.h>

int main()

{
int i,N,sum,high,r,d,k;
char c;
scanf("%d %c",&N,&c);
sum=0;
for(i=1;sum<=N;i++)
{
sum=2ii-1;
}
high=i-2;
sum=2highhigh-1;
r=N-sum;
for(d=high;d>0;d--)
{
if(d<high)
{
for(k=high-d;k>0;k--)
{
printf(" ");
}
}
for(i=2*d-1;i>0;i--)
{
printf("%c",c);
}
printf("\n");

}for(d=2;d<=high;d++){        if(d
0;k--) { printf(" "); } } for(i=2*d-1;i>0;i--) { printf("%c",c); } printf("\n");}printf("%d\n",r);

}

(2)设计思路
1.首先定义变量。
2.注意刚好打印沙漏最少要大于等于7,先计算出打印沙漏需要sum个,剩余r个。再进行沙漏打印和空格处理,最后输出r.
1581766-20190221150319290-1145608079.png

(3)错误及解决办法

错误:空格处理不当;出现格式错误。
解决办法:查找本题出现过得错误,改正答案。
(4)运行结果如截图
1581766-20190220143424334-715762918.png

转载于:https://www.cnblogs.com/1211li/p/10406467.html

你可能感兴趣的文章
那些在学习iOS开发前就应该知道的事
查看>>
python多线程--Condition(条件对象)
查看>>
c++汉诺塔相关知识总结1
查看>>
Gym 100169A 最短路
查看>>
android 中activity调用本地service中的方法。
查看>>
强制IE浏览器或WebBrowser控件使用指定版本显示网页(转发)
查看>>
OJDBC版本区别
查看>>
中国网建之SMS
查看>>
《SQL 进阶教程》 case:练习题1-1-2 转换行列——在表头里加入汇总列
查看>>
展讯NAND Flash高级教程【转】
查看>>
DynamicPropertyAccessor Expression lambda
查看>>
csc.rsp Invent by Microshaoft
查看>>
CentOS7上GitHub/GitLab多帐号管理SSH Key
查看>>
字符串+变量
查看>>
style
查看>>
Log4j配置详解
查看>>
myql 查询树形表结果:说说、说说的述评、评论的回复
查看>>
java基础讲解02-----eclipse快捷方式(2017-04-12 23:47)
查看>>
Eclipse使用Tomcat发布项目时出现YadisException异常解决方案
查看>>
How to do Mathematics
查看>>