【c++】C语言之输入行数,输出实心菱形和空心菱形

输出菱形

编程自动输出如下图形,由屏幕输入指定行数(奇数),实现后封装为函数,以行数作为参数值。

在这里插入图片描述

   输入一个n,表示左边两个菱形图形(实心和空心)的行数(或者一半行数)  
   利用循环语句实现输出。说明:此题相当于两个题,要打印出两个图。
  提示:第一个菱形分析*号个数和规律;第二题分析*出现位置及变化规律

做题思路

先输出上半部分,再输出下部分
这样就相当于输出一个正三角形和一个倒三角形。
并且正三角形的行数比倒三角形的行数多一行,多出的一行是两个三角形的线。

正三角形

for(i=1; i<=n; i++)//上半部分 
	{
		for(j=1; j<=n-i; j++)//"n-i"当前行第一个星号左边的空格数//
			cout << ' ';
		for(j=1; j<=2*i-1; j++)//"2*i-1"为当前行的星号数// 
			cout << '*';
		cout << endl;//换行//
	}

倒三角形

for(i=n; i>=1; i--)//下半部分
	{
		for(j=1; j<=n-i+1; j++)//"n-i"当前行第一个星号左边的空格数// 
			cout << ' ';
		for(j=1; j<=2*i-1; j++)//"2*i-1"为当前行的星号数// 
			cout << '*';
		cout << endl;//换行//
	}

改变两者的n

n_u=n/2+1;//上半部分行数
n_l=n/2;//下半部分行数 

在这里插入图片描述

代码:

#include <iostream>
using namespace std;
int main()
{
	int n,i,j,n_u,n_l;
	cout << "输入行数一个奇数:";
	cin >> n;
	n_u=n/2+1;//上半部分行数
	n_l=n/2;//下半部分行数 
	for(i=1; i<=n_u; i++)//上半部分 
	{
		for(j=1; j<=n_u-i; j++)//"n_u-i"当前行第一个星号左边的空格数//
			cout << ' ';
		for(j=1; j<=2*i-1; j++)//"2*i-1"为当前行的星号数// 
			cout << '*';
		cout << endl;//换行//
	}
	for(i=n_l; i>=1; i--)//下半部分
	{
		for(j=1; j<=n_l-i+1; j++)//"n_l-i"当前行第一个星号左边的空格数// 
			cout << ' ';
		for(j=1; j<=2*i-1; j++)//"2*i-1"为当前行的星号数// 
			cout << '*';
		cout << endl;//换行//
	}
}

空心菱形

做题思路

先输出上半部分,再输出下部分
这样就相当于输出一个正三角形和一个倒三角形。
并且正三角形的行数比倒三角形的行数多一行,多出的一行是两个三角形的线。

在实心的基础上改进
不同点在于*的输出

if(i==1)
			cout << '*';
		else{
			cout << '*';
			for(j=1; j<=2*(i-1)-1; j++)//"2*i-1"为当前行的星号数// 
			    cout << ' ';
			cout << '*';
		}

结果

在这里插入图片描述

代码

#include <iostream>
using namespace std;
int main()
{
	int n,i,j,n_u,n_l;
	cout << "输入行数一个奇数:";
	cin >> n;
	n_u=n/2+1;//上半部分行数
	n_l=n/2;//下半部分行数 
	for(i=1; i<=n_u; i++)//上半部分 
	{
		for(j=1; j<=n_u-i; j++)//"n_u-i"当前行第一个星号左边的空格数//
			cout << ' ';
		
		if(i==1)
			cout << '*';
		else{
			cout << '*';
			for(j=1; j<=2*(i-1)-1; j++)//"2*i-1"为当前行的星号数// 
			    cout << ' ';
			cout << '*';
		}
		
		cout << endl;//换行//
	}
	for(i=n_l; i>=1; i--)//下半部分
	{
		for(j=1; j<=n_l-i+1; j++)//"n_l-i"当前行第一个星号左边的空格数// 
			cout << ' ';
		if(i==1)
			cout << '*';
		else{
			cout << '*';
			for(j=1; j<=2*(i-1)-1; j++)//"2*i-1"为当前行的星号数// 
			cout << ' ';
			cout << '*';
		}
		
		cout << endl;//换行//
	}
}

版权声明:本文为qq_46556714原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
THE END
< <上一篇
下一篇>>