第一题、

#include<bits/stdc++.h>
using namespace std;
int main()
{
int a[100][100]={0};
int n;
cin>>n;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
if(i+j==n)
{
a[i][j]=1;
}
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
cout<<setw(3)<<a[i][j];
}
cout<<endl;
}
return 0;
}
第二题、
#include<bits/stdc++.h>
using namespace std;
int main()
{
int a[100][100]={0};
int n;
cin>>n;
int k=1;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
a[i][j]=k;
k++;
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
cout<<setw(3)<<a[i][j];
}
cout<<endl;
}
return 0;
}
第三题、

#include<bits/stdc++.h>
using namespace std;
int main()
{
int a[100][100]={0};
int n;
cin>>n;
int k=1;
for(int i=n;i>=1;i--)
{
for(int j=1;j<=n;j++)
{
a[i][j]=k;
k++;
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
cout<<setw(3)<<a[i][j];
}
cout<<endl;
}
return 0;
}
第四题、
#include<bits/stdc++.h>
using namespace std;
int main()
{
int a[100][100];
int n;
cin>>n;
int k=1;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
a[j][i]=k;
k++;
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
cout<<setw(3)<<a[i][j]<<" ";
}
cout<<endl;
}
return 0;
}
第五题、

#include<bits/stdc++.h>
using namespace std;
int main()
{
int a[100][100];
int n;
cin>>n;
int k=1;
for(int i=n;i>=1;i--)
{
for(int j=1;j<=n;j++)
{
a[j][i]=k;
k++;
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
cout<<setw(3)<<a[i][j]<<" ";
}
cout<<endl;
}
return 0;
}
这五段代码是用C++编写的,分别展示了五种不同的矩阵填充方式:对角线填充1,行填充递增序列,列填充递增序列,右下到左上对角线填充递增序列,以及左下到右上对角线填充递增序列。每段代码读取矩阵的大小(n),然后初始化一个n×n的二维数组并进行相应填充,最后打印输出矩阵。

被折叠的 条评论
为什么被折叠?



