天梯赛L1打印沙漏(c++)

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

*****
 ***
  *
*****
 ***
  *

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

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

代码如下:

#include<iostream> 
using namespace std; 

int main()
{
	int n;//给定符号的个数 
	char ch;//给定符号 
	cin>>n;
	cin>>ch;
	int a=1; 
	int b=1;//b是剩余的符号个数 


//1111计算可以输出的函数2c-1,以及剩余符号数b	 	
for(a=1;b>=0;a++)
{
	b=n-(2*a*a-1);//用a,来计算可以最多的行数(2c-1)	
 }  
 int c;
 c=a-2;//即上面输出c行,下面输出c-1行 ,本例子就是c=3 
 b=n-(2*c*c-1);//不能组成沙漏的计算剩余的符号个数 
 

 //22222打印上面的部分
 for(int i=1;i<=c;i++)//重复c次, 打印出前c行 
 {
 	for(int k=i-1;k>0;k--)//先输出特定空格 
	 {
	 	cout<<" "; 
	  } 
 
 	for(int j=2*c-1-(i-1)*2;j>0;j--)//输出特定数目给定符号 
	 {
	 	cout<<ch;
	  } 
	  
	  cout<<endl; //换行 
 }
 
 //33333打印下面的部分
 for(int i=c-1;i>0;i--)//打印下面的c-1行 
 {
 	for(int k=i-1;k--;k>0)//先输出特定空格数 
	 {
 	cout<<" "; 
     }
 	for(int j=2*c-1-(i-1)*2;j>0;j--)//再输出特定的符号数 
	 {
	 	cout<<ch;
	  } 
	  cout<<endl; //换行 
 }
 
 //cout<<"还剩余"<<b; 
 cout<<b;//输出剩余的符号个数b 
 return 0; 	
 } 


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值