思路:
1.先定义一个一维数组和一个二维数组,
一维数组的大小和二维数组大小相等,
2.二维数组元素放到一维数组中 ,用冒泡排序等方法对一维数组进行排序,
3.然后在将一维数组放到二维数组中,
4.最后将二维数组中数据先行后列方式从大到小的顺序排列后以矩阵形式输出
封装的冒泡排序方法↓
static void sortArr1(int[] arr1)
{
for(int i = 0; i < arr1.Length - 1; i++)
{
for(int j=0;j<arr1.Length-1-i;j++)
{
if(arr1[j]<arr1[j+1])
{
int tmp = arr1[j];
arr1[j] = arr1[j + 1];
arr1[j + 1] = tmp;
}
}
}
算法↓
Console.Write("请输入二维数组的行:");
int row = int.Parse(Console.ReadLine());
Console.Write("请输入二维数组的列:");
int col = int.Parse(Console.ReadLine());
int[,] arr2 = new int[row, col];
int[] arr1 = new int[row * col];
for (int i = 0; i < row; i++)
{
for (int j = 0; j < col; j++)
{
arr2[i, j] = r.Next(0, 50);
arr1[i * col + j] = arr2[i, j];//二维数组元素放到一维数组中
}
}
sortArr1(arr1);
//一维数组元素放到二维数组中
for (int i = 0; i < arr1.Length; i++)
{
int curRow = i / col;
int curCol = i % col;
arr2[curRow, curCol] = arr1[i];
}
//二维数组中数据先行后列方式从大到小的顺序排列后以矩阵形式输出
int sum1 = 0;
int sum2 = 0;
for (int i = 0; i < row; i++)
{
for (int j = 0; j < col; j++)
{
if (j == col - 1)//最后一个元素
{
Console.WriteLine(arr2[i, j]);
}
else
{
Console.Write(arr2[i, j] + ",");
}
if (i == j)
{
sum1 += arr2[i, j];//主对角线
}
if (i + j == col - 1)
{
sum2 += arr2[i, j];//副对角线
}
}
}
Console.WriteLine("主对角线之和:{0},副对角线之和:{1}", sum1, sum2);