1077: 空心菱形

空心菱形,是我OJ题中遇到的较为麻烦的一道题。初做时思路较为凌乱,便先空着,转眼将近一个个月过去,整合平日里的思路,便得以下ji故此便做出文章,来记录这时的思路,以便后续遇到空心三角形、矩形、甚至较为复杂的图案以提供思路。也希望能帮助到屏幕前的你。

#include<stdio.h>
int main()
{
	int n,k,i,j=-1,j1,p,p1;//这里的k是为了输出整体空心菱形的左半边 ,j、j1是为了输出右上空心菱形的右半边
	//p、p1是为了输出空心菱形的右下部分
	scanf("%d",&n);
	for(i=1;i<=n;i++,j=j+2)
	{
		 k=n-i; 
		 while(k>0)//此步骤可以输出第i行的第一个'*'号前的k个空格 
		 {
		 	k--;
		 	printf(" ");
		 }
		 printf("*");//不能有'\n',以便第二个星号紧随其后 
		 j1=j;//将j的值赋值给j1的原因是j要参与for循环
//我们可以发现,第二行的两个星号之间有一个空格,第三行有三个空格(两星号之间的空格呈等差数列)...以此类推,
		 //所以让j=-1的目的是既可以避免多输出第一行的星号,又可以输出第i(i>1)行两星号之间的j个空格
		 while(j1>0)//避免多输出第一行的星号 
		 {
		     while(j1>0)//输出两星号之间的空格
		 {
		 	j1--;
		 	printf(" ");
		 }
		 printf("*");	
		 }
		 printf("\n");//输出一行星号之后,换行 
	}
	p=j-4;//以便输出下半部分两星号之间的空格 
	for(i=n-1;i>=1;i--,p=p-2)
	{
		k=n-i;
		while(k>0)
		{
			k--;
			printf(" ");
		}
		printf("*");
		p1=p;
		while(p1>0)//同上,避免最后多输出一个星号 
		{
			while(p1>0)
			{
				p1--;
				printf(" ");
			}
			printf("*");
		}
		printf("\n");
	}
	return 0; 
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值