自测-1 打印沙漏 (20分)

#include

int n;
char a;
int l; //记录最长的一行有多少个符号
int sum=1;
int rest;
int space;
int icon;
int s;
int i;

int  main()
{
	scanf("%d %c",&n,&a);
	if(n<5){
		rest=n-1;
		printf("%c\n%d",a,rest);
		return 0;
	}
	for(l=3;sum<=n;l+=2){  //测试余数为0的情况,此处sum<=n而不是sum=1;icon-=2){
		space=(l-icon)/2;
		for(s=space;s>0;s--){
			printf(" ");
		}
		for(i=icon;i>0;i--){
			printf("%c",a);
		}
		printf("\n");
	}
	for(icon=3;icon<=l;icon+=2){
		space=(l-icon)/2;
		for(s=space;s>0;s--){
			printf(" ");
		}
		for(i=icon;i>0;i--){
			printf("%c",a);
		}
		printf("\n");
	}
	printf("%d",rest);

}

你可能感兴趣的:(自测-1 打印沙漏 (20分))