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





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

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

代码:#include <stdio.h>
int main()
{
int n;
char c;
scanf("%d %c",&n,&c);
int sum=1;
int i=1;
while(sum<=n)
{
sum+=2(2(i+1)-1);
if(sum<=n)
i++;
}
int j,k;
for(j=0;j<i;j++)
{
for(k=0;k<j;k++)
printf(" ");
for(k=0;k<2(i-j)-1;k++)
{
printf("%c",c);
}
printf("\n");
}
for(j=2;j<=i;j++)
{
for(k=0;k<i-j;k++)
printf(" ");
for(k=0;k<2
j-1;k++)
{
printf("%c",c);
}
printf("\n");
}
printf("%d",n-(sum-2(2(i+1)-1)));
return 0;
}

设计思路:1.题目上半部分需要一行比一行少,用while确定给出数目17该打印几行。
2.给出上半部分下半部分只需要跟上半部分对称。
3.for循环打印,注意顶行,printf(“\n”)
4.结尾注意用公式算出剩余星号数目。

运行结果:

最新文章

  1. UVA 11210 中国麻将
  2. jQuery判断网页中的id是否有重复的
  3. Azure自动化实例: 复制blog用于备份
  4. footer元素
  5. 【枚举】bzoj3391 [Usaco2004 Dec]Tree Cutting网络破坏
  6. ASP.NET Web – AJAX 回送
  7. json.net xml转换为json格式时,如何将指定节点转换成数组
  8. linux安装和配置 mysql、redis 过程中遇到的问题记录(转)
  9. 浙大pat 1025题解
  10. php的autoload机制
  11. LINUX 笔记-vmstat命令
  12. LeetCode Questions List (LeetCode 问题列表)- Java Solutions
  13. [加密]C#实现维吉尼亚加密与解密(解密前提为已知密匙)
  14. ajax如何增加请求头
  15. solr7.7.0搜索引擎使用(三)(添加文件索引)
  16. sqlserver 自动创建作业执行备份数据库
  17. LCD1602小程序
  18. delphi Overload 和override的区别
  19. shell编程(一)
  20. 数据类型比较:Long和BigDecimal

热门文章

  1. Eclipse常用设置及快捷键
  2. 单双通道对RTX有何影响?结果出乎意料
  3. Jupyter Notebook(推荐使用Anaconda安装)
  4. Floyd算法——计算图中任意两点之间的最短路径
  5. Vivado怎么使用In system debug(类似于chipscope的东西)
  6. rest framework 序列化
  7. Scrapy-redis 组件
  8. 位运算之——按位与(&amp;)操作——(快速取模算法)
  9. WS_TABSTOP 与 BS_DEFPUSHBUTTON 第一次使有
  10. PMP备考资料和备考经验分享(基于PMP第六版)