L1-002 打印沙漏 (20 分)

#include
int main()

{
	char str1 = ' ';
	int Nrow = 1, remainder = 0, line = 1, n,i,j,k,compare;
	scanf("%d %c", &n,&str1);
	for ( i = 1; i <=n; i = i + (line * 2)) //从第2,3 每行3个符号 开始,i=沙漏的每行总数之和 
	{
		line = line + 2;   //每行为奇数行 3,5,7 ++2;
		Nrow += 2;  //两行进行一次计算
		if (i > n)break; //符号总数加起来超过给出的符号数时跳出循环
	}
	i = i - (line * 2);   //然后把上一次的循环值消减去;
	Nrow -=2;
	remainder = n - i; // 最后计算 余数;
	compare = Nrow;  //用来做比较
	Nrow = (Nrow + 1) / 2; //打印上半个正三角形  
	for (i = 0; i < Nrow; i++)    //循环从1行开始到Nrow行
	{
		for (j = 0; j < i; j++)    
			printf(" ");
		for (j = 0; j < 2 * Nrow - 2 * i - 1; j++)  //利用奇数行*2 再减去 2*i-1; 求出顶行;然后利用j++每行递减循环;
			printf("%c",str1);
		printf("\n");
	}
	for (int i = 1; i <=compare-Nrow; i++)  //打印后半个倒三角 i的范围利用原先的Nrow-上半个三角形使用掉的循环来计算剩下的还有多少循环;
	{
		for (k = 1; k 

 

你可能感兴趣的:(算法)