#include<iostream>
#include<cmath>
using namespace std;
int main()
{
int s;
char m;
cin >> s >> m;
int n;
n = sqrt((s + 1) / 2);
int flag = (2 * n - 1);
int count;
for (count = 0; flag > 0; count++)
{
for (int j = 0; j < count; j++)
{
cout << ' ';
}
for (int i = 1; i <= flag; i++)
{
cout << m;
}
n--;
flag = 2 * n - 1;
cout << endl;
}
int count1 = count;
for (int i = 2; i <= count1; i++)
{
for (int j = 1; j <= count - i; j++)
{
cout << ' ';
count--;
}
for (int k = 1; k <= 2 * i - 1; k++)
{
cout << m;
}
cout << endl;
}
int end = s - (2 * count1 * count1 - 1);
cout << end;
}
PTA的1027 打印沙漏,请问测试点0和3为什么格式错误
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- qzjhjxj 2022-02-15 21:25关注
题主考虑的太复杂了,精简下,供参考:
#include <iostream> #include <cmath> using namespace std; int main() { int s, n; char m; cin>>s>>m; n=sqrt((s+1)/2); for(int i=n;i>0;i--) { for(int j=1;j<=n-i;j++) cout<<" "; for(int j=2*i-1;j>=1;j--) cout<<m; cout<<endl; } for(int i=2;i<=n;i++) { for(int j=n-i;j>=1;j--) cout<<" "; for(int j=1;j<=2*i-1;j++) cout<<m; cout<<endl; } cout<<(s-(2*n*n-1)); return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
- ¥20 软件测试决策法疑问求解答
- ¥15 win11 23H2删除推荐的项目,支持注册表等
- ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
- ¥15 qt6.6.3 基于百度云的语音识别 不会改
- ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
- ¥15 神经网络怎么把隐含层变量融合到损失函数中?
- ¥15 lingo18勾选global solver求解使用的算法
- ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行
- ¥20 测距传感器数据手册i2c