zoukankan      html  css  js  c++  java
  • 打印沙漏

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





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

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

    include<stdio.h>

    int main()
    {
    int n;
    char c;
    scanf("%d %c",&n,&c);
    int i=1,sum=1;
    while(sum<=n)
    {
    sum+=2(2(i+1)-1);
    i++;
    }
    i=i-1;
    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(" ");
    }
    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(" ");
    }
    printf("%d",n-(sum-2(2(i+1)-1)));
    return 0;
    }
    2).设计思路

    3)本题调试过程遇到的问题及解决办法
    刚开始不知如何下手,翻看了之前的类似题的做法,但是还是不知道如何去累加字符,看了一些大佬的做法,她们是通过数列来累加字符的,才写完这题。然后本题没有错误截屏。
    4)运行结果截图

  • 相关阅读:
    过河卒 NOIp 2002 dp
    [POI2014]KUR-Couriers BZOJ3524 主席树
    【模板】可持久化线段树 1(主席树)
    EXPEDI
    取石子游戏 BZOJ1874 博弈
    【模板】文艺平衡树(Splay) 区间翻转 BZOJ 3223
    关于表白
    POJ 1951
    Codeforces 1032F Vasya and Maximum Matching dp
    Codeforces 1016F Road Projects
  • 原文地址:https://www.cnblogs.com/1234-tst/p/10369737.html
Copyright © 2011-2022 走看看