C语言输出任意边长的菱形

目录
  •      1.简单理解星号输出原理,将输出星号代码分为上方和下方两部分
  •      2.上方输出星号代码
  •      3.下方输出星号代码
  • 全部代码如下

        经过一段时间的学习后,想必大家都已经开始摩拳擦掌,迫不及待地想用C语言写一些程序了。

        那么今天,我们就来学习C语言中常见的例子——输出任意边长的菱形

        适用范围:学习并掌握了C语言循环以及之前的内容

        

        上面图片中用黄色a标示出来的便是菱形的边长,图片中为3,当然,也可以理解为(星号的行数+1)/2

        那么,废话不多说,上教程

     1.简单理解星号输出原理,将输出星号代码分为上方和下方两部分

        首先,我们可以观察到如果边长为a的话,那么最长的一行的长度就为2*a-1,同时,每列星号都是对齐的,这说明我们如果想要输出星号,是有规律可循的,没星号的地方我们可以用空格来代替,这样一想,发现,我们好像可以使用x轴区间来控制空格和星号的输出

        例如,第三行,如果我们设第一个星号的x坐标为1的话,并在此基础上输出5个星号,那我们只需要写一串代码去控制在x属于[1,5]的区间上输出星号就行了

        同样,对于图片中第一行来说,我们只需要写一串代码来控制在x属于(2,4)的区间上输出一个星号就行了,如下

for(int j=1;j<2*3-1;j++)    //3为图片中菱形的边长
{
    if(j>2&&j<4)
        printf("*");
    else
        printf(" ");
}

        现在,由于行数不同,每行输出的星号数也就不同,那么,我们就可以找出输出星号数和行数的的关系

        但是,我们又可以看出,最长的一行星号上面的星号输出方式为由少到多,而最长一行下面的星号输出方式为由多到少,那么,对于上面和下面,我们要找的星号数与行数的关系也是不同的

     2.上方输出星号代码

        那么,接下来,我们先讨论最长一行星号的上方(包括最长一行星号),输出星号数与行数的关系

        首先,我们要遍历最长一行上方的所有行(包括最长一行),这时,就要用到for循环,这里的a表示最长的一行的行数,同时也是菱形的边长

for(int i=1;i<=a;i++)

        接下来,我们要找到行数与输出星号数的关系 

        经过观察,我们发现,如果a为边长,i表示行数,那么则在(a-i,2*a-(a-i))区间上要输出星号

     看到这里的友友们可以停下来思考一下,思考通了在接着看 

        好的,那么接下来,我们要遍历列,单单遍历行是不够的,不能控制星号以及空格的输出,所以,我们就需要遍历列

        如下,我们用到了输出星号的区间,如果列数在区间(a-i,2*a-(a-i))内,就输出星号,不在区间内,就输出空格,这样,就可以控制输出星号以及行数的关系了。

        当然,也别忘了,每输出一行星号就要换行,所以要写printf("\n"),但要写在遍历列for循环的外面,遍历行for循环的里面

        这就是上方输出星号的全部了,看到这儿,是不是想尝试自己编写下方星号的输出了呢,如果想的话,那就大胆的去尝试一下(* ̄︶ ̄)

    for (int i = 1; i <= a; i++)	//遍历菱形最长一行上方(包括最长的一行)所有行
	{
		printf(" ");	//每行前面加空格,整齐好看
		for (int j = 1; j<=2*a-1; j++)
        //遍历菱形最长一行上方(包括最长的一行)每行的所有列
		{
			if (j > a - i&& j <2 * a - (a - i))
				printf("*");
			else
				printf(" ");
		}
		printf("\n");
	}

     3.下方输出星号代码

        好的,那么下面,我们讨论最长一行星号的下方(不包括最长一行星号),输出星号数与行数的关系

        先写下方的遍历行,我们是从最长的一行的下一行开始输出,最长的一行的行数为a,那么,我们要定义行的初始值为a+1,行的最大值为2*a-1

        就像上方输出星号一样,接着要找输出星号的区间,经过观察,可以发现,列数在区间(i-a,2*a-(i-a))内,就输出星号,不在区间内,就输出空格,这样,就可以控制输出星号以及行数的关系了。

        接下来,要遍历列,代码如下

for(int i=a+1;i<=2*a-1;i++)

        当然,也别忘了,每输出一行星号就要换行,所以要写printf("\n"),但要写在遍历列for循环的外面,遍历行for循环的里面

        这就是下方输出星号的全部了(* ̄︶ ̄)

    for (int i =  a + 1; i <= 2*a-1 ; i++)	//遍历菱形最长一行上方(包括最长的一行)所有行
	{
		printf(" ");	//每行前面加空格,整齐好看
		for (int j = 1; j <= 2 * a - 1; j++)
		//遍历菱形最长一行下方(不包括最长的一行)每行的所有列
		{
			if (j > i - a && j < 2*a - (i - a))
				printf("*");
			else
				printf(" ");
		}
		printf("\n");
	}

全部代码如下

#include <stdio.h>
#include <stdlib.h>
int main(void)
{
	int a;	//菱形的边长
	//注意,由于屏幕的大小限制,过大的边长(比如100)会导致无法输出正常的菱形,望理解
	printf("输入菱形的边长:\n");
	scanf_s("%d", &a);
	for (int i = 1; i <= a; i++)	//遍历菱形最长一行上方(包括最长的一行)所有行
	{
		printf(" ");	//每行前面加空格,整齐好看
		for (int j = 1; j<=2*a-1; j++)
        //遍历菱形最长一行上方(包括最长的一行)每行的所有列
		{
			if (j > a - i&& j <2 * a - (a - i))
				printf("*");
			else
				printf(" ");
		}
		printf("\n");
	}
	for (int i =  a + 1; i < 2*a + 1; i++)	//遍历菱形最长一行上方(包括最长的一行)所有行
	{
		printf(" ");	//每行前面加空格,不和边框拥挤,可去掉
		for (int j = 1; j <= 2 * a - 1; j++)
        //遍历菱形最长一行下方(不包括最长的一行)每行的所有列
		{
			if (j > i - a && j < 2*a - (i - a))
				printf("*");
			else
				printf(" ");
		}
		printf("\n");
	}
	system("pause");
	return 0;
}

到此这篇关于C语言输出任意边长的菱形的文章就介绍到这了,更多相关C语言菱形内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C语言打印菱形实例详解

    前言 打印菱形这道题对于初学编程者来说简直是噩梦,曾经我就是栽在这上面的,后来编程编多了之后对打印菱形也觉得不再那么难了,去年在公众号写了一篇推送是关于打印菱形的,觉得对一些师弟师妹还是有所帮助的,今天就把这道题分享出来. 以下是我遇到的各种各样的菱形: 普通菱形,输入n,输出n行n列的菱形 难度系数:♥ n行空心菱形,输入n,输出n行空心菱形 难度系数:♥♥ n行挖空菱形,输入n,输出n行n列空格菱形 难度系数:♥♥♥ n行数字菱形,输入n,输入n行数字从外到内递增的数字菱形 难度系数:♥♥♥

  • C语言输出任意边长的菱形

    目录      1.简单理解星号输出原理,将输出星号代码分为上方和下方两部分      2.上方输出星号代码      3.下方输出星号代码 全部代码如下         经过一段时间的学习后,想必大家都已经开始摩拳擦掌,迫不及待地想用C语言写一些程序了.         那么今天,我们就来学习C语言中常见的例子--输出任意边长的菱形         适用范围:学习并掌握了C语言循环以及之前的内容                  上面图片中用黄色a标示出来的便是菱形的边长,图片中为3,当然,也

  • C语言输入三角形边长判断其类型并输出面积实例代码

    本文主要研究的是输入三角形边长判断其类型并输出面积,用C语言实现,具体如下. 思路:首先判断所给的三条边是否能够组成三角形,若可以组成三角形,则判断该三角形是什么类型,并求三角形的面积. 相关知识: 三角形是由同一平面内不在同一直线上的三条线段'首尾'顺次连接所组成的封闭图形.常见的三角形按边分有普通三角形(三条边都不相等),等腰三角(腰与底不等的等腰三角形.腰与底相等的等腰三角形即等边三角形) 不等边三角形:不等边三角形,数学定义,指的是三条边都不相等的三角形叫不等边三角形. 等腰三角形:等腰

  • Python3实现打印任意宽度的菱形代码

    我就废话不多说了,还是直接看代码吧! width = 11 #注意宽度必须位奇数 for i in range(-width//2,width//2+1): prespace=i if i>0 else -i print(' '*prespace+'*'*(width-prespace*2)) 运行结果: * *** ***** ******* ********* *********** ********* ******* ***** *** * 补充知识:Python打印高度为2 * n +

  • C语言实现任意进制转换器

    本文实例为大家分享了C语言实现任意进制转换器的具体代码,供大家参考,具体内容如下 简单的C语言任意进制转换器 该进制转换器可进行任意进制转换,请看效果图: 代码 /** ******函数声明 ******进制函数,输入与输出 void main(); ******返回将n进制num转换成的十进制数 int NToD(char *num,int n); ******将十进制数d转换成m进制数mnum void DToM(int d,int m,char *mnum); */ #include<st

  • 用Python实现写倒序输出(任意位数)

    目录 Python写倒序输出(任意位数) 倒序输出数字 逆序输出一个数字Python Python写倒序输出(任意位数) 倒序输出数字 这种方法最后输出的是字符而不是数字 x=int(input('请输入任意一个数字:')) y=str(x)  #转换为字符串 l=len(y) #长度 a=[] for i in range(l):     a.append(y[l-1-i]) # print(a) for j in a:     print(j,end='') 这种的话输出的就是任意位数字的倒

  • 使用c语言输出杨辉三角形的简单方法

    问题描述 杨辉三角形又称Pascal三角形,它的第i+1行是(a+b)^n的展开式的系数. 它的一个重要性质是:三角形中的每个数字等于它两肩上的数字相加. 下面给出了杨辉三角形的前4行: 1 1 1 1 2 1 1 3 3 1 下面要求用户输入一个整数n,然后输出杨辉三角形的前n行. 示例代码如下: #include<stdio.h> int main() { int a[100][100],i,j,num; printf("请输入需要打印的行数:"); scanf(&qu

  • C语言数组任意位置插入一个元素方法

    前言: 这篇文章我们来看看向C语言的数组中随机插入一个元素的方法. 如果是在python向列表中随机添加元素,我们往往使用insert()的方法. l = ['Python', 'C++', 'Java'] #插入元素 l.insert(1, 'C') print(l) #插入元组,整个元祖被当成一个元素 t = ('C#', 'Go') l.insert(2, t) print(l) #插入列表,整个列表被当成一个元素 l.insert(3, ['Ruby', 'SQL']) print(l)

  • 如何利用C语言输出3D立体感心形图详解

    目录 ★头文件部分: ★主函数外自定义函数部分: ★主函数部分: 总结 首先我先在每行(除空白以及{}外)代码上标上序号(无序号源码放在了文末) #include <stdio.h> #include <math.h> float f(float x, float y, float z) { float a = x*x + 9.0f/4.0f*y*y + z*z - 1; return a*a*a - x*x*z*z*z - 9.0f/80.0f*y*y*z*z*z; } floa

  • C语言输出孪生素数的实现示例

    目录 1.题目内容: 2.输入格式: 3输出格式: 1.题目内容: 孪生素数是指间隔为 2 的相邻素数,例如最小的孪生素数对是3和5,5和7也是(5虽重复但算作2组). 2.输入格式: 输入N,找出2至N之间的孪生素数的组数. 这里要注意输入的N不要超过int表示的最大范围了 3输出格式: 输出2至N之间的孪生素数,然后输出组数. 代码如下: #include<stdio.h> int Function(int n)//函数判断是否为素数 {     for (int i=2; i<n;

  • java实现输出任意整数的每一位

    目录 输出任意整数的每一位 非递归方式 递归方式 输出一个整数的每一位 输出任意整数的每一位 非递归方式 import java.util.*; public class Exe{ public static void main(String[] args){ Scanner input = new Scanner(System.in); System.out.println("请输入一个整数:"); int count = input.nextInt(); int m,i=1,j,t

随机推荐