C语言方式实现求矩阵最大值

题目描述:

给定一个仅包含0和1的N*N二维矩阵,请计算二维矩阵的最大值,计算规则如下:

  • 每行元素按下标顺序组成一个二进制数(下标越大越排在低位),二进制数的值就是该行的值。矩阵各行值之和为矩阵的值。
  • 允许通过向左或向右整体循环移动每行元素来改变各元素在行中的位置。 比如:
  • [1,0,1,1,1]向右整体循环移动2位变为[1,1,1,0,1],二进制数为11101,值为29。
  • [1,0,1,1,1]向左整体循环移动2位变为[1,1,1,1,0],二进制数为11110,值为30。

输入描述:

  • 输入的第一行为正整数,记录了N的大小,0 < N <= 20。
  • 输入的第2到N+1行为二维矩阵信息,行内元素半角逗号分隔。

输出描述:

  • 矩阵的最大值。

示例

输入
5
1,0,0,0,1
0,0,0,1,1
0,1,0,1,0
1,0,0,1,1
1,0,1,0,1
输出
122

参考代码(2022-05-26)

#include<stdio.h>
#include<string.h>

// 删除字符串中的','
void Delete_Character(char *pStr)
{
	char *p = pStr;
	while (*pStr != '\0')
	{
		if (*pStr != ',')
		{
			*p++ = *pStr;
		}
		pStr++;
 	}
	*p = '\0';
}

// 计算每行数据中最大值
int Calcuate_Each_Line(char a[], int num)
{
	int idxI = 0, idxJ = 0, sum = 0, tmp = 0;
	char *pArr = (char*)malloc(sizeof(char)*num);

	// 移位计算
	for (idxI = 0; idxI < num; idxI++)
	{
		tmp = 0;
		for (idxJ = 0; idxJ < num; idxJ++)
		{
			// 对数据进行移动,例如[1,0,1] => [0,1,1] => [1,1,0]
			pArr[idxJ] = a[(idxI + idxJ) % num];
		}
		// 右移方式按位与操作计算大小
		for (idxJ = 0; idxJ < num; idxJ++)
		{
			tmp |= (pArr[idxJ] - '0') << (idxJ);
		}
		// 取最大值
		if (sum < tmp)
		{
			sum = tmp;
		}
	}
	free(pArr);
	return sum;
}


int main(void)
{
	int matrixNum = 0, idx = 0;
	char *pLineStr = NULL;
	int MatrixSum = 0;

	scanf("%d", &matrixNum);
	getchar();
	if (matrixNum < 1 || matrixNum > 20)
	{
		printf("inputted the number is error\n");
		return -1;
	}
	pLineStr = (char*)malloc(sizeof(char)* matrixNum * 2);

	for (idx = 0; idx < matrixNum; idx++)
	{
		// 输入矩阵中一行数据
		gets(pLineStr);
		// 删除字符串中的逗号
		Delete_Character(pLineStr);
		// 计算每一行数据中最大值
		MatrixSum += Calcuate_Each_Line(pLineStr, matrixNum);
	}
	printf("%d", MatrixSum);

	free(pLineStr);
	return 0;
}

优化后的参考代码(2022-06-17)

PS:最近回头看之前做的算法题,发现之前的一些答案不是很完美,可以优化的地方太多了,这算是一种成长吧!

// 计算矩阵中每一行的最大值
int calc_each_line(int a[], int n)
{
	int max = 0, tmp = 0;
	int i, j;

	for (i = 0; i < n; i++)
	{
		tmp = 0;
		for (j = 0; j < n; j++)
		{
			/* 移位计算
			对数据进行移动,例如[1,0,1] => [0,1,1] => [1,1,0]
			右移方式按位与操作计算大小
			*/
			tmp |= a[j] << ((i + j) % n);
		}
		// 取最大值
		max = max > tmp ? max : tmp;
	}
	return max;
}

/**
** 矩阵最大值
** 给定一个仅包含0和1的N*N二维矩阵,请计算二维矩阵的最大值
**/
int calc_max_matrix()
{
	int matrixCnt, max, i, j;
	int a[10] = { 0 };
	int tmp;

	scanf("%d", &matrixCnt);
	tmp = matrixCnt;

	max = 0;
	while (tmp--)
	{
		for (i = 0; i < matrixCnt - 1; i++)
		{
			scanf("%d,", &a[i]);
		}
		scanf("%d", &a[i]);

		// 计算每一行数据中最大值
		max += calc_each_line(a, matrixCnt);
	}

	printf("%d", max);

	return 0;
}
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值