金字塔及空心菱形问题

经典的打印金字塔

1)使用 for 循环完成下面的案例
2)请编写一个程序,可以接收一个整数,表示层数(totalLevel),打印出金字塔。(stars.c) [化繁为简, 先死后活]
3) 思路分析
在这里插入图片描述

打印矩形

#include<stdio.h>
void main(){
	
	
	//打印矩形
	int i,j;
	
	for(i = 1; i<=5;i++){
		for(j=1;j<=5;j++){
			printf("*");
		}
		printf("\n");
	} 
		
}

在这里插入图片描述

打印半个金字塔

#include<stdio.h>
void main() {

	//打印半个金字塔
	int i,j;

	for(i = 1; i<=5; i++) {
		for(j=1; j<=i; j++) {
			printf("*");
		}
		printf("\n");
	}
}

在这里插入图片描述

打印整个金字塔

#include<stdio.h>
void main() {
	//打印整个金字塔 
	/*
	
		* // 1 个 * (2 * i - 1) = 2 * 1 - 1= 1 空格有 4 (总的层数-i) = 5-1=4
	   *** // 3 个 * (2 * i - 1) = 2 * 2 - 1= 3 空格有 3 (总的层数-i) = 5-2=3
	  ***** // 5 个 * (2 * i - 1) = 2 * 3 - 1= 5 空格有 2 (总的层数-i) = 5-3=2
	 ******* // 7 个 * (2 * i - 1) = 2 * 4 - 1= 7 空格有 1 (总的层数-i) = 5-4=1
	********* // 9 个* (2 * i - 1) = 2 * 5 - 1= 9 空格有 0 (总的层数-i) = 5-5=0
    
	*/

	int i,j,k;
	
	for(i = 1;i <= 5;i++){
		for(k = 1;k <= 5 - i;k++){
			printf(" ");
			
			}
			for(j = 1;j <= 2 * i - 1;j++){
				printf("*");
			}
			
		printf("\n");
	}
	
}

在这里插入图片描述

打印空心金字塔

#include<stdio.h>
void main(){
	
	
	//打印空心金字塔 
	//在输出 * 号的时候,需要考虑是否输出的*还是空格 
	//分析
	/*
		* // i = 1 该输入* 就输入 * 
	   * * // 如果是 第一个* 和最后一个* 输出的*, 其它应该输入 空格 
	  *   * // 如果是 第一个* 和最后一个* 输出的*, 其它应该输入 空格 
	 *     * // 如果是 第一个* 和最后一个* 输出的*, 其它应该输入 空格 
	********* // i = 5 该输入* 就输入 * 

	*/
	int i,j,k;
	
	for(i = 1;i <= 5;i++){
		for(k = 1;k <= 5 - i;k++){
			printf(" ");
			
			}
			for(j = 1;j <= 2 * i - 1;j++){
				
				if(j == 1 || j == 2 * i - 1 || i == 5){
					printf("*");
				}else{
					printf(" ");
				}
			
			}
		printf("\n");
	}
}

在这里插入图片描述

打印空心菱形

用的平面直角坐标系的方式解决的如下程序:

#include<stdio.h>
void main(){
	
	//打印空心菱形
	/*
			*
		   * *
		  *   *
		 *     *
		*       *
		 *     *
		  *   *
		   * *
		    *
	
	
	*/
	int x; //x轴
	int y; //y轴
	int length ; //长度
	int o; //长度的二倍
	
	printf("请输入菱形的最长对角线的长度:");
	getchar();
	scanf("%d",&length);
	
	o = length / 2;
	
	for(y = -o;y <= o;y++){
		for(x = -o;x <= o;x++){
			
			//(第四象限,第三象限,第二象限,第一象限)
			if((x == o - y) || (x == y - o) || (x == -y - o) || (x == y + o )){
				printf("*");
			}else{
				printf(" ");
			}
		}
		printf("\n");
	}	
	
}

在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值