第1个回答 2019-05-26
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
typedef struct
{
int data;
int index; //保存数组下标
} N1;
void sort(N1 a[], int len)
{
N1 temp;
for (int i = 0; i < len - 1; i++)
for (int j = 0; j < len - 1 - i; j++)
if (a[j].data > a[j + 1].data)
{
temp = a[j];
a[j] = a[j + 1];
a[j + 1] = temp;
}
}
int main()
{
int a[5][5] = {{6, 7, 18, 9, 14},
{5, 24, 2, 9, 10},
{22, 8, 5, 1, 8},
{4, 12, 5, 7, 2},
{13, 33, 8, 7, 9}};
int temp = 0;
int sa[] = {0, 4, 20, 24};
int *p;
N1 b[25];
p = &a[0][0];
for (int i = 0; i < 25; i++)
{
b[i].data = *p;
b[i].index = i;
p++;
}
sort(b, 25);
p = &a[0][0];
//交换4个角
for (int i = 0; i < 4; i++)
{
temp = p[sa[i]];
p[sa[i]] = p[b[i].index];
p[b[i].index] = temp;
}
//交换中心
temp = p[12];
p[12] = p[b[24].index];
p[b[24].index] = temp;
for (int i = 0; i < 5; i++)
{
for (int j = 0; j < 5; j++)
{
printf("%d ", a[i][j]);
}
printf("\n");
}
return 0;
}
第2个回答 2019-05-27
C代码:
#include<stdio.h>
void main()
{
void change(int x[][5]);
int a[5][5]={{100,99,98,97,96},{95,94,93,92,91},{90,89,88,87,86},{85,84,83,82,81},{80,79,78,77,76}};
int i,j;
printf("转换前:\n");
for(i=0;i<5;i++)
{
for(j=0;j<5;j++)
printf("%4d",a[i][j]);
printf("\n");
}
change(a);/*调用函数*/
printf("转换后:\n");
for(i=0;i<5;i++)
{
for(j=0;j<5;j++)
printf("%4d",a[i][j]);
printf("\n");
}
}
void change(int x[][5])
{
int b[25],i,j,k=0,t;
for(i=0;i<5;i++)/*把二维数组中元素按行的顺序存放到一维数组*/
for(j=0;j<5;j++)
{
b[k]=x[i][j];
k++;
}
for(i=0;i<24;i++)/*选择排序法,对一维数组中元素进行从小到大的排序*/
{
k=i;
for(j=i+1;j<25;j++)
if(b[j]<b[k])
k=j;
if(k!=i)
{
t=b[k];
b[k]=b[i];
b[i]=t;
}
}
for(i=0;i<5;i++)
for(j=0;j<5;j++)
if(x[i][j]==b[24])
{
t=x[i][j];
x[i][j]=x[2][2];
x[2][2]=t;
break;
}
for(i=0;i<5;i++)
for(j=0;j<5;j++)
if(x[i][j]==b[0])
{
t=x[i][j];
x[i][j]=x[0][0];
x[0][0]=t;
break;
}
for(i=0;i<5;i++)
for(j=0;j<5;j++)
if(x[i][j]==b[1])
{
t=x[i][j];
x[i][j]=x[0][4];
x[0][4]=t;
break;
}
for(i=0;i<5;i++)
for(j=0;j<5;j++)
if(x[i][j]==b[2])
{
t=x[i][j];
x[i][j]=x[4][0];
x[4][0]=t;
break;
}
for(i=0;i<5;i++)
for(j=0;j<5;j++)
if(x[i][j]==b[3])
{
t=x[i][j];
x[i][j]=x[4][4];
x[4][4]=t;
break;
}
}
C++代码:
#include<iostream>
#include<iomanip>
using namespace std;
int main()
{
void change(int x[][5]);
int a[5][5]={{100,99,98,97,96},{95,94,93,92,91},{90,89,88,87,86},{85,84,83,82,81},{80,79,78,77,76}};
int i,j;
cout<<"转换前:"<<endl;
for(i=0;i<5;i++)
{
for(j=0;j<5;j++)
cout<<setw(4)<<a[i][j];
cout<<endl;
}
change(a);/*调用函数*/
cout<<"转换后:"<<endl;
for(i=0;i<5;i++)
{
for(j=0;j<5;j++)
cout<<setw(4)<<a[i][j];
cout<<endl;
}
return 0;
}
void change(int x[][5])
{
int b[25],i,j,k=0,t;
for(i=0;i<5;i++)/*把二维数组中元素按行的顺序存放到一维数组*/
for(j=0;j<5;j++)
{
b[k]=x[i][j];
k++;
}
for(i=0;i<24;i++)/*选择排序法,对一维数组中元素进行从小到大的排序*/
{
k=i;
for(j=i+1;j<25;j++)
if(b[j]<b[k])
k=j;
if(k!=i)
{
t=b[k];
b[k]=b[i];
b[i]=t;
}
}
for(i=0;i<5;i++)
for(j=0;j<5;j++)
if(x[i][j]==b[24])
{
t=x[i][j];
x[i][j]=x[2][2];
x[2][2]=t;
break;
}
for(i=0;i<5;i++)
for(j=0;j<5;j++)
if(x[i][j]==b[0])
{
t=x[i][j];
x[i][j]=x[0][0];
x[0][0]=t;
break;
}
for(i=0;i<5;i++)
for(j=0;j<5;j++)
if(x[i][j]==b[1])
{
t=x[i][j];
x[i][j]=x[0][4];
x[0][4]=t;
break;
}
for(i=0;i<5;i++)
for(j=0;j<5;j++)
if(x[i][j]==b[2])
{
t=x[i][j];
x[i][j]=x[4][0];
x[4][0]=t;
break;
}
for(i=0;i<5;i++)
for(j=0;j<5;j++)
if(x[i][j]==b[3])
{
t=x[i][j];
x[i][j]=x[4][4];
x[4][4]=t;
break;
}
}