PAT乙级 1027 打印沙漏 (20 分)

版权声明:博主版权所有,未经允许,禁止转载!转载前请联系[email protected],谢谢合作,一起交流学习! https://blog.csdn.net/googlemzhang/article/details/90167817

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

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

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

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

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

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

输入样例:
19 *
输出样例:

*****
 ***
  *
 ***
*****
2

题目链接:https://pintia.cn/problem-sets/994805260223102976/problems/994805294251491328

思路:当用scanf函数处理一个数字和一个字符输入时,应该注意中间加空格划分(因为空格,回车也是单个字符,会被%c吸收),重点代码处我加了注释,不懂的话再问我哈。

#include <bits/stdc++.h>
using namespace std;

int main()
{
	int n;
	char ch;
	int x;
	while(scanf("%d %c",&n,&ch)==2)
	{//输入一个数字和一个字符 
		int sum = 0;
		int index = 0;	//记录i的下标 
		for(int i=1;;i+=2)
		{
			sum += i;
			if((2*sum-1)>=n)
			{
				index = i;
				break;	
			}	
		}
		if(sum==n)//当前累加和正好为n 
		{
			x = 0;
		}
		else if((2*sum-1)>n)
		{//多加一次i			
			sum -= index;
			index -= 2;
			x = n-(2*sum-1);
		}
		//printf("index=%d\n",index);
		for(int i=index;i>=1;i-=2)
		{
			for(int j=0;j<(index-i)/2;j++)
				printf(" ");
			for(int k=0;k<i;k++)
			{				
				printf("%c",ch);
			} 
			printf("\n");
		}
		for(int i=3;i<=index;i+=2)
		{
			for(int j=0;j<(index-i)/2;j++)
				printf(" ");
			for(int k=0;k<i;k++)
				printf("%c",ch);
			printf("\n");
		}

		printf("%d\n",x);
	} 
	return 0;
}

猜你喜欢

转载自blog.csdn.net/googlemzhang/article/details/90167817