暮色苍然

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

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





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

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

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

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

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





2

一,实验代码:

#include<stdio.h>
int main()
{
	int N,b=1,remainder,count=0,count_1=0,ce=0;
	double hang=1,lie;
	int a,c,point,point_1;
	char op;
	
	scanf("%d %c",&N,&op); 
	for(;N-b>0;)
	{
		hang+=2;
		b=b+hang*2;
		count++;
	}
	if(N==b)
		remainder=0;
	else
	{
		b=b-hang*2;
		count--;
		hang-=2;
		remainder=N-b;
	}
	lie=hang;
	point=hang-count;
	point_1=point-1;
	for(a=1;a<=hang/2+0.5;a++)
	{
		for(c=1;c<=lie;c++)
		{
			if(a==1)
				printf("%c",op);
			if(a>1&&c<=point-point_1||c>point+point_1)
				{
					printf(" ");
					ce++;
				}
			if (a>1&&c>point-point_1&&c<point+point_1)
				printf("%c",op);
			if(c==lie)
				printf("\n");
		}
		count_1++;
		lie-=1;
		if(a>=2)
			point_1-=1;
	}
	a=a-2;
	point_1+=2;
	lie=lie+count_1;
	for(;a>=1;a--)
	{
		for(c=1;c<=lie;c++)
		{
			if(a==1)
				printf("%c",op);
			if(a>1&&c<=point-point_1)
				{
				printf(" ");
				ce++;
				}
			if (a>1&&c>point-point_1&&c<point+point_1)
				printf("%c",op);
			if(c==lie)
				printf("\n");
			}
	if(a>=2)
		point_1+=1;
	}
	printf("%d\n",remainder);

	return 0;
}

二,设计思路:

一种思路就是将代码分为两大部分,第一大部分主要用来算出参数N最少需要多少数目的符号,多少行和剩余多少符号没用,其数目会分别储存至参数b,hang和remainder中,这部分还有其他的一些参数如point,point_1等,这些主要用于第二大部分控制符号输出规律。第二大部分用来输出图像,这部分代码又可以分成两小部分我将其分为A,B两部分。A部分用来输出漏斗的上半部分,B部分用来输出漏斗的下半部分,然后都用for语句嵌套循环,外循环控制行,内循环控制列。A,B部分的内循环中用在if语句中所加入的算式来判断该行的每一列应该输出符号还是空格。当图形输出完毕后,在图形下方输出参数remainder的值即剩余符号数即可。
有一个注意的小细节,就是题中给出的输出案例,图形只有左侧存在空格,而右侧则不存在空格,即在输出完每行需要输出的符号后就跳转到下一行继续输出,且每一行所需要输出的符号数是呈一定规律变化的。因此需要添加相应的参数来控制符号输出的规律,我所添加的相应参数就是point和point_1。

posted on 2019-01-17 13:54  暮色苍然  阅读(268)  评论(0编辑  收藏  举报