菱形以及各种组合图形讲解(*#@¥$&)

引言:

++***形对于新手了解循环以及嵌套循环帮助是非常大的。(以下的题各题之间有关联)++

++我们最终目的,就是会编程写菱形;看下面的图片++

++++

解题思路:运用++拆分法++ ,我们将菱形分为4个部分,看图:

接下来,我们从基础开始弄。

第一题(学会输出):

先来一个简单的图形,入门一下;

样例输入1:3
输出:
cpp 复制代码
##
##
##
样例输入2:7
输出:
cpp 复制代码
##
##
##
##
##
##
##
代码1(性质与代码2相同):
cs 复制代码
#include <bits/stdc++.h>
using namespace std;
int main()
{
	int n;
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		cout<<"##"<<endl;
	}	
	return 0;
} 
代码2:
cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int main()
{
	int n;
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=2;j++)
		{
		    cout<<"#"; 	
		}
		cout<<endl;
	}	
	return 0;
} 

++OK,已经算入门了,接下来上强度。++

第二题(学会递增输出):
样例输入1:7
样例输出1:
cpp 复制代码
#
##
###
####
#####
######
#######      //第七行   七个#
样例输入2:10
样例输出2:
cpp 复制代码
#
##
###
####
#####
######
#######
########
#########
##########       //第十行  十个#
代码:
cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int main()
{
	int n;
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=i;j++)
		{
		    cout<<"#"; 	
		}
		cout<<endl;
	}	
	return 0;
} 
第三题(学会递减输出):
样例输入一:3
样例输出一:
cpp 复制代码
###
##
#
样例输入一: 7
样例输出二:
cpp 复制代码
#######
######
#####
####
###
##
#
代码:
cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int main()
{
	int n;
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		for(int j=n;j>=i;j=j-1)      //着重了解本行
		{
		    cout<<"#";
			 	
		}
		cout<<endl;
	}	
	return 0;
} 
第四题(学会运用空格搭配输出):
样例输入一:5
样例输出一:
cpp 复制代码
     #
    ##
   ###
  ####
 #####
样例输入一: 7
样例输出二:
cpp 复制代码
       #
      ##
     ###
    ####
   #####
  ######
 #######
代码:
cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int main()
{
	int n;
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		for(int j=n;j>=i;j=j-1)
		{
		    cout<<" ";
			 	
		}
		for(int j=1;j<=i;j++)
		{
			cout<<"#";
		}
		cout<<endl;
	}	
	return 0;
} 
第五题(组合输出):

样例输入一:6

样例输出:

cpp 复制代码
      #
     ###
    #####
   #######
  #########
 ###########
cpp 复制代码
#include <bits/stdc++.h>      
using namespace std;
int main()
{
	int n;
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		for(int j=n;j>=i;j=j-1)
		{
		    cout<<" ";
			 	
		}
		for(int j=1;j<=i;j++)
		{
			cout<<"#";
		}
		for(int j=1;j<=i-1;j++)   //新加的代码,注意i-1
		{
			cout<<"#";            //新加的代码
		}		
		cout<<endl;              //新加的代码
	
	}	
	
	return 0;
} 
第六题(拼凑菱形):
样例输入一:6
样例输出二: 菱形(6+5行)
cpp 复制代码
      #
     ###
    #####
   #######
  #########
 ###########
  #########
   #######
    #####
     ###
      #
代码:
cpp 复制代码
#include <bits/stdc++.h>      
using namespace std;
int main()
{
	int n;
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		for(int j=n;j>=i;j=j-1)
		{
		    cout<<" ";
			 	
		}
		for(int j=1;j<=i;j++)
		{
			cout<<"#";
		}
		for(int j=1;j<=i-1;j++)   
		{
			cout<<"#";            
		}		
		cout<<endl;              
	
	}
		for(int i=1;i<=n;i++)     //新加的代码
	{
			for(int k=1;k<=i+1;k++)     //新加的代码
		{
			cout<<" ";
		}
		for(int j=n-i;j>=1;j--)       //新加的代码
		{
		    cout<<"#"; 	
		}
	    for(int y=i;y<=n-2;y++)       //新加的代码
	    {
	    	cout<<"#";
		}
		cout<<endl;
	}
	return 0;
	}
++大功告成,到这里,你基本上掌握了输出图形的技巧,但这对于很多奇形怪状的图形还不够,还得继续学习,加油,程序员!!!++
相关推荐
泉崎18 分钟前
11.7比赛总结
数据结构·算法
你好helloworld20 分钟前
滑动窗口最大值
数据结构·算法·leetcode
AI街潜水的八角1 小时前
基于C++的决策树C4.5机器学习算法(不调包)
c++·算法·决策树·机器学习
白榆maple1 小时前
(蓝桥杯C/C++)——基础算法(下)
算法
JSU_曾是此间年少1 小时前
数据结构——线性表与链表
数据结构·c++·算法
sjsjs112 小时前
【数据结构-合法括号字符串】【hard】【拼多多面试题】力扣32. 最长有效括号
数据结构·leetcode
此生只爱蛋2 小时前
【手撕排序2】快速排序
c语言·c++·算法·排序算法
blammmp3 小时前
Java:数据结构-枚举
java·开发语言·数据结构
昂子的博客3 小时前
基础数据结构——队列(链表实现)
数据结构
咕咕吖3 小时前
对称二叉树(力扣101)
算法·leetcode·职场和发展