C/C++ 多重循环练习:回型方阵
题目描述
输入一个正整数n,输出n×n的回型方阵。
输入
一行一个正整数n,2≤n≤100。
输出
共n行,每行包含n个正整数,之间用一个空格隔开。
样例输入
5
样例输出
1 1 1 1 1
1 2 2 2 1
1 2 3 2 1
1 2 2 2 1
1 1 1 1 1
看完,你是不是有一点思路了呢?对的!这道题简单的很!
像铺地毯一样,一层层铺下去。
#include<iostream>
using namespace std;
int i,j,n,a[1005][1005],l=1,k;
int main()
{
cin>>n;
for(i=1;i<=(n+1)/2;i++)//控制“铺地毯”次数
{
for(j=i;j<=n-i+1;j++) //控制“铺地毯”的行数(第一次是n,第二次是n-2)
{
for(k=i;k<=n-i+1;k++)//控制“铺地毯”的列数(跟行数一样)
a[j][k]=l;//铺地毯
}
l++;//铺地毯的数字++
}
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++)
cout<<a[i][j]<<" ";//输出方阵
cout<<endl;
}
return 0;
}