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

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

                                    ——————————打印沙漏

7-1 打印沙漏 (20 分)

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




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

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

输入格式:

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

输出格式:

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

输入样例:

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


2

(1)实验代码
#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)));
}

思路:先细读题目所要,确认我们所需要求,由题目可知,我们编写的是一段需要打印出沙漏形状的一段代码;首先定义一些题目中要用到的字符,然后定义条件,创造所需要的循环,进行所需要的循环,这里我们是先用while循环,然后在定义了另外的for循环,最后经过多次修改调试,得到了正确的代码

运行截图:

 

转载于:https://www.cnblogs.com/langz594212/p/10389473.html

你可能感兴趣的文章
Windows Phone 7 ListBox 经典问题详解,带你更深入了解listbox
查看>>
深入探究VC —— 编译器cl.exe(2)【转】http://blog.csdn.net/wangningyu/article/details/4837419...
查看>>
跟我一起写 Makefile
查看>>
iOS UICollectionView 在滚动时停在某个item位置上
查看>>
第二章 Vue快速入门--14 使用v-model实现计算器的案例
查看>>
回文数判断
查看>>
SqlBulkCopy 用法
查看>>
awt多线程聊天
查看>>
linux搭建apache服务并修改默认路径
查看>>
Windows资源管理器打开文件夹卡顿原因及解决办法
查看>>
linux中fork()函数详解
查看>>
Spring框架基础(中)
查看>>
java文件的读写程序代码
查看>>
NOIP200703守望者的逃离
查看>>
SmbException: 0xC000007F
查看>>
UVA 12627 气球胀啊胀
查看>>
Apache 的ab压力测试工具
查看>>
linux进程状态D
查看>>
256.Paint House
查看>>
Java7中的文件和目录管理----Path类
查看>>