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

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

7-1 打印沙漏 (20 分)

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





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

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

输入格式:

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

输出格式:

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

输入样例:

19
输出样例:
****
***



  • 2

我的代码:

include <stdio.h>

int N;

char ch;
int main()
{
int i,j,k,ln;
int sum=1,maxans;
scanf("%d %c",&N,&ch);
for(i=3;;i+=2)
{
if(sum+2i<=N)
sum+=(2
i);
else
{
maxans=i-2;
break;
}
}
for(ln=1;ln<=maxans/2+1;ln++)
{
for(j=1;j<ln;j++)
printf(" ");
for(k=maxans-(ln-1)2;k>=1;k--)
printf("%c",ch);
printf("\n");
}
for(ln=maxans/2;ln>=1;ln--)
{
for(j=1;j<ln;j++)
printf(" ");
for(k=maxans-(ln-1)
2;k>=1;k--)
printf("%c",ch);
printf("\n");
}
printf("%d\n",N-sum);
return 0;
}
实验思路:
第一步:首先定义所需变量。
第二步:思考打印行数和每行前面的空格,以及打印符号的个数。
第三步:计算给定值与符号个数的差并打印。
第四步:结束程序。
错误结果:
1581901-20190220095442328-969366072.png

分析:未打印给定值与符号个数的差,导致部分错误。(没找到自己的截图)

运行结果:
1581901-20190220100131413-1214927397.png

转载于:https://www.cnblogs.com/leichen210/p/10404883.html

你可能感兴趣的文章
Android 四大组件之BroadcastReceiver
查看>>
0927-练习
查看>>
android TextView属性详解
查看>>
redis 主从同步搭建
查看>>
Wp7中,使你的程序在程序列表中的名称自适应手机语言设置
查看>>
error: .repo/manifests/: contains uncommitted changes
查看>>
逆元(inv)
查看>>
CentOS Docker 安装
查看>>
debian(kali Linux) 安装net Core
查看>>
centos 7防火墙设置
查看>>
自定义进度条(圆形、横向进度条)
查看>>
spark-streaming-kafka采坑
查看>>
9.Mongodb与python交互
查看>>
18-[JavaScript]-函数,Object对象,定时器,正则表达式
查看>>
读取短信回执
查看>>
EF 数据初始化
查看>>
PreparedStatement与Statement
查看>>
WebService -- Java 实现之 CXF ( 使用CXF工具生成client 程序)
查看>>
Factorial
查看>>
Android开发中,9-patch 图片设置背景带来的问题
查看>>