首页 > 其他分享 >天梯赛-L1002题

天梯赛-L1002题

时间:2022-10-12 15:00:22浏览次数:52  
标签:L1002 num1 沙漏 符号 int i1 天梯 flag1

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

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

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

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

输入格式:

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

输出格式:

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

输入样例:

19 *
 

输出样例:

*****
 ***
  *
 ***
*****
2
#include<stdio.h>
int main()
{
	char c;
	int num;
	scanf("%d %c",&num,&c);
	int num1,num2=1,sum=0,flag=0,flag1=1,num5;
	num1=num-1;
	num1=num1/2;
	for(int i=1;;i++)
	{
		num2+=2;
		sum+=num2;
			flag=i;
		if(num1<=sum)
		{
            flag=flag-1;
			sum=sum-num2;
			break;
		
		}
	}
	for(int i=flag;i>=1;i--)
	{
		int i1,flag1;
		i1=i;
		flag1=flag;
		while(flag1-i1)
		{
			printf(" ");
			i1++;
		}
	for(int j=1;j<=2*i+1;j++)
	{
		printf("%c",c);
		}
		printf("\n");	
	}
	for(int i=1;i<=flag;i++)
	{
		printf(" ");
	}
	printf("%c",c);
	printf("\n");
	for(int i=1;i<=flag;i++)
	{
		int i1,flag1;
		i1=i;
		flag1=flag;
		while(flag1-i1)
		{
			printf(" ");
			i1++;
		}
		for(int j=1;j<=i*2+1;j++)
		{
			printf("%c",c);
		}
		printf("\n");
	}
	num5=num-2*sum-1;
	printf("%d",num5);
}

  

标签:L1002,num1,沙漏,符号,int,i1,天梯,flag1
From: https://www.cnblogs.com/5ran2yl/p/16784546.html

相关文章