问题:输入一个N阶方阵,按照如下方式调整方阵:1.将第一列中最大数所在的行与第一行对调; 2.将第二列中从第二行到第N行最大数所在的行与第二行对调;...

问题:输入一个N(N<=10)阶方阵,按照如下方式调整方阵:
1.将第一列中最大数所在的行与第一行对调。
2.将第二列中从第二行到第N行最大数所在的行与第二行对调。

N-1.将第N-1列中从第N-1行到第N行最大数所在的行与第N-1行对调。
N.输出这个方阵
样例输入
4
3 6 8 7
6 7 5 3
8 6 5 3
9 8 7 2

样例输出:
9 8 7 2
6 7 5 3
3 6 8 7
8 6 5 3
解题思路:等以后有时间再写

解决代码:

#include<stdio.h>
#include<stdlib.h>
int main(){
	int n,*p;
	scanf("%d",&n);
	//C语言只接受常量作为数组下标,只能通过动态创建空间来模拟二维数组 
	p=(int *)malloc(sizeof(int)*n*n);	//创建二维数组内存空间 
	for(int i=0;i<n;i++){				//按行输入数组元素 
		for(int j=0;j<n;j++)
			scanf("%d",p+n*i+j);		//A[i][j]==*(p+n*i+j)
	}
	//对矩阵进行处理
	for(int i=0;i<n;i++){
		int max=i;						//将该列最大数的所在行数记录到max里面
		for(int j=i;j<n;j++){ 	 		//因为第一行对调后放置不管 
			if(*(p+n*j+i)>*(p+n*max+i)){//所以j=i,来跳过已经对调过的处于上层的行 
				max=j;
			}
		}
		int tmp;						 
		for(int j=0;j<n;j++){			//将第i列中从第i行到第n行最大数所在的行与第max(i<=max<=n)行对调 
			tmp=*(p+n*max+j);
			*(p+n*max+j)=*(p+n*i+j);
			*(p+n*i+j)=tmp;
		} 
	} 
	
	for(int i=0;i<n;i++){				//按行输入数组元素 
		for(int j=0;j<n;j++){
			printf("%d ",*(p+n*i+j));	//A[i][j]==*(p+n*i+j)
		}
		printf("\n"); 
	}
} 

运行结果:
在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值