ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

金字塔及空心菱形问题

2021-12-18 22:01:59  阅读:141  来源: 互联网

标签:int 打印 空心 空格 菱形 printf 金字塔


文章目录

经典的打印金字塔

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");
	}	
	
}

在这里插入图片描述

标签:int,打印,空心,空格,菱形,printf,金字塔
来源: https://blog.csdn.net/weixin_45417821/article/details/122013834

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有