(C语言)将一个5乘5矩阵中最大的数放在中心,四个角分别放4个最小的元素(顺序为从左到右,从上到下依次从小到大存放),写一函数实现,在面函数中调用(指针的方法处理)

将一个5乘5矩阵中最大的数放在中心,四个角分别放4个最小的元素(顺序为从左到右,从上到下依次从小到大存放),写一函数实现,在面函数中调用(指针的方法处理)

值得注意的是:
对于二维数组例如: a[2][2]
a表示的整个数组的首地址,a[0]表示的是第一行的首地址,这两者者在数值上是一样的,但含义不同(或者说类型不同),数组名a是对于整个数组(类型为 int(*)[2] ),a[0]是对于第一行(类型为 int* )

二维数组的解引用(以二维数组a为例)

*(*(a + i) + j)相当于a[i][j]

#include<stdio.h>
#include<stdlib.h>
#define N 5
void swop(int* a, int* b) {//交换两个数,两个形参为指针
	*a = *a ^ *b;
	*b = *a ^ *b;
	*a = *a ^ *b;
}
void fun(int(*p)[N]){
	int* max = (int*)p;//最大值
	int* min1 = (int*)p;//最小值
	for (int i = 0; i < N; ++i) {
		for (int j = 0; j < N; ++j) {
			if (*max < *(*(p + i) + j)) {
				max = *(p + i) + j;
			}
			if (*min1 > *(*(p + i) + j)) {
				min1 = *(p + i) + j;
			}
		}
	}
	int* min2 = *(p + 2) + 2;//次小值
	int* min3 = *(p + 2) + 2; //倒数第三小值
	int* min4 = *(p + 2) + 2;//倒数第四小值

	swop(max, *(p + 2) + 2);//最大值与中间的值交换
	swop(min1, *p);//最小值与左上角的值交换
	for (int i = 0; i < N; ++i) {
		for (int j = 0; j < N; ++j) {
			if (*(p + i) + j == *p) {
				continue;
			}
			if (*min2 > *(*(p + i) + j)) {
				min2 = *(p + i) + j;
			}
		}
	}
	swop(min2, *(p)+N - 1);//次小值与右上角的值交换
	for (int i = 0; i < N; ++i) {
		for (int j = 0; j < N; ++j) {
			if (*(p + i) + j == *p || *(p + i) + j ==*(p)+N - 1) {
				continue;
			}
			if (*min3 > *(*(p + i) + j)) {
				min3 = *(p + i) + j;
			}
		}
	}
	swop(min3, *(p + N - 1));//倒数第三小值与左下角的值交换
	for (int i = 0; i < N; ++i) {
		for (int j = 0; j < N; ++j) {
			if (*(p + i) + j == *p || *(p + i) + j == *(p)+N - 1 || *(p + i) + j == *(p + N - 1)) {
				continue;
			}
			if (*min4 > *(*(p + i) + j)) {
				min4 = *(p + i) + j;
			}
		}
	}
	swop(min4, *(p + N - 1) + N - 1); //倒数第四小值右下角的值交换
}
void main() {
	int arr[N][N];
	int(*p)[N] = arr;//定义指向二维数组的指针p
	int count = 25;
	for (int i = 0; i < N; ++i) {//初始化二维数组
		for (int j = 0; j < N; ++j) {
			*(*(p + i) + j) = count;
			count -= 1;
		}
	}
	printf("原数组为\n");
	for (int i = 0; i < N; ++i) {
		for (int j = 0; j < N; ++j) {
			printf("%d\t", *(*(p + i) + j));
		}
		printf("\n");
	}
	printf("\n\n转换后的数组为\n");
	fun(p);
	for (int i = 0; i < N; ++i) {
		for (int j = 0; j < N; ++j) {
			printf("%d\t", *(*(p + i) + j));
		}
		printf("\n");
	}
	system("pause");
}


在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值