B-1027 打印沙漏 (20分)

这篇文章详细介绍了如何使用C++编写一个打印沙漏效果的程序,通过控制字符和空格输出上下三角形,适用于教学或小型项目。

B-1027 打印沙漏 (20分)

在这里插入图片描述

#include <iostream>
using namespace std;

int main(){
    int n,c,h,i=3,j,k,f,w,sum=0,s;
    char m;
    cin >> n >> m;
    if(n<7){//如果数量小于7,不能形成上下三角
        cout<<m<<endl;
        cout<<n-1;
        return 0;
    }//以下对三角形的处理均不包括中间一点
    w=(n-1)/2;//求出一半三角形可用的顶点数
    for(i=3;sum<w;i+=2){//求出一半三角形最大所需的顶点数
        sum+=i;
    }
    sum=sum-i+2;
    h=i-4;
    c=(i-1)/2;
    s=n-(sum*2+1);
    for(k=1;k<c;k++){//上三角
        for(j=1;j<k;j++){//输出空格
            cout << ' ';
        }
        for(f=0;f<h;f++){//输出字符
            cout << m;
        }
        h-=2;
        cout<<endl;
    }
    h=3;
    for(k=c-1;k>1;k--){//下三角同理
        for(j=k-2;j>0;j--){
            cout << ' ';
        }
        for(f=0;f<h;f++){
            cout << m;
        }
        h+=2;
        cout<<endl;
    }
    cout << s;
    return 0;
}
以下是几种不同编程语言实现将给定符号打印沙漏形状的方法: #### C语言实现 ```c #include<stdio.h> #include<math.h> int main() { int s = 0; char ch; scanf("%d %c", &s, &ch); if (s > 1) { int num = 0; int sl = 0; num = sqrt((s + 1) / 2); sl = s + 1 - 2 * pow(num, 2); num = 2 * num - 1; // 最多个数 int i = 0; int j = 0; int k = 0; int count = 0; for (i = num; i > 0;) { count = (num - i) / 2; for (k = count; k > 0; k--) printf(" "); for (j = i; j > 0; j--) printf("%c", ch); printf("\n"); i = i - 2; } i = 0; j = 0; for (i = 3; i < num + 1;) { count = (num - i) / 2; for (k = count; k > 0; k--) printf(" "); for (j = i; j > 0; j--) printf("%c", ch); printf("\n"); i = i + 2; } printf("%d\n", sl); } return 0; } ``` #### C#实现 ```csharp using System; class Program { static void Main(string[] args) { string line; string[] tokens; while ((line = System.Console.ReadLine()) != null) { tokens = line.Split(' '); int a = int.Parse(tokens[0]); char b = char.Parse(tokens[1]); int sum = 1; int i; for (i = 2; sum <= a; i++) { sum += (i * 2 - 1) * 2; } sum -= ((i - 1) * 2 - 1) * 2; i -= 2; int unuse = a - sum; // 打印 for (int j = i; j > 0; j--) // 上半部 { for (int c = 0; c < i - j; c++) { Console.Write(" "); } for (int k = 0; k < 2 * j - 1; k++) { Console.Write(b); } Console.WriteLine(); } for (int j = 1; j <= i - 1; j++) { for (int c = 0; c < i - j - 1; c++) { Console.Write(" "); } for (int k = 0; k < 2 * j + 1; k++) { Console.Write(b); } Console.WriteLine(); } Console.WriteLine(unuse); } Console.ReadKey(); } } ``` #### Python实现 ```python n, ch = input().split() n = int(n) # 计算最大层数 layer = 1 used = 1 while used + (2 * (layer + 1) - 1) * 2 <= n: layer += 1 used += (2 * layer - 1) * 2 unused = n - used # 打印上半部 for i in range(layer, 0, -1): spaces = ' ' * (layer - i) stars = ch * (2 * i - 1) print(spaces + stars) # 打印下半部 for i in range(2, layer + 1): spaces = ' ' * (layer - i) stars = ch * (2 * i - 1) print(spaces + stars) print(unused) ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值