题目:
题目乍一看非常的简单,属于初学者都会的问题——————————但是实际上呢,有一些小小的坑在里面。
就是三角形的打印。
平常我们在写代码的时候,遇到打印三角形的题,一般简简单单两个for循环搞定
#include<iostream>
using namespace std;
int main()
{
int n;
cin>>n;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=i;j++)
{
cout<<j;
}
cout<<endl;
}
return 0;
}
输出来的三角形是这样的
而题目要求的则是考右边的三角形。
一开始想到了printf来对其.....可是试了很多遍三角形都无法靠左边。
在一筹莫展之际突然灵光一闪——————可以在第二轮for循环之前再加上一个for循环来控制空格的输出。
将空格稍微补齐我们可以发现,第一行缺了6个,第二行缺了4个,第三行缺了2个,第四行缺了0个。
本来应该是第一行缺n-1个,导致这种情况的原因是三角形出现了补0。所以导致每一行长度都变成了原来的2倍。所以将循环开始的条件改成2(n-1)问题就解决了。
最后上代码:
#include<iostream>
#include<algorithm>
using namespace std;
int n;
int main()
{
cin>>n;
int a=1;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
if(a<10)
{
cout<<"0"<<a;
}
else if(a>=10)
{
cout<<a;
}
a++;
}
cout<<endl;
}
cout<<endl;
int b=1;
for(int i=1;i<=n;i++)
{
for(int z = 2*n-2*i; z >=1; z--)
{
cout<<" ";
}
for(int j=1;j<=i;j++)
{
if(b<10)
{
cout<<"0"<<b;
}
else if(b>=10)
{
cout<<b;
}
b++;
}
cout<<endl;
}
return 0;
}