c语言-C语言中关于矩阵算法的问题

问题描述

C语言中关于矩阵算法的问题

从一个m×n的整数矩阵中,找到x×y的子矩阵,使子矩阵中所有元素的和最大,并输出和及子矩阵所有元素。算法实现的思路是怎么样的?

解决方案

http://blog.sina.com.cn/s/blog_a46817ff01013xgw.html

解决方案二:

http://blog.csdn.net/beiyeqingteng/article/details/7056687

解决方案三:

给一种思路,把子矩阵看着一个滑动的窗口,进行遍历,计算和的时候计算滑动出去和新进来的数据的差。

解决方案四:

遍历M * N 的数组 中所有 X * Y矩阵集合 然后记录最大值,返回
给你写个 伪代码:
引用你的 m n x y 的值 架设 array为 你的二维数组
if(x <=0 || x> m || y <=0 || y>n) return;
int sum = 0;
int sumMax = 0; //记录最大值
int x_index = 0;//记录 X 坐标
int y_index = 0;//记录Y 坐标
int Pos_w = m - x + 1; //计算出 矩阵横向移动次数
int Pow_h = m - y + 1;//计算出 矩阵竖向移动次数
for(int i= 0 ;i< Pos_w *Pow_h; ++i)
{
sum = 0; //清空
//获取该子矩阵的和
for(int j = 0; j < x * y; ++j)
{
sum += array[j / x + i / Pos_w, j % x + i%Pos_w];
}
if (sum > sumMax)
{
x_index = i % Pos_w;
y_index = i / Pos_w;
sumMax = sum;
}
}
你只要 用 x_index 和 y_index 就可以了 记住 这个 坐标 记录的是 你所需要的子矩阵中 左上角的坐标 从 0,0开始。
Y 代表 矩阵中的第几行 X 代表 第几列。 我在写运算的时候 已经把 二维转换成 一维了,优化代码的作用。
如果不理解的话 可以在问我 你直接套用即可。

时间: 2024-08-17 21:45:43

c语言-C语言中关于矩阵算法的问题的相关文章

c语言-C语言中临界矩阵转换为双向链域表示一个带权的无向图,设计一种算法的表示

问题描述 C语言中临界矩阵转换为双向链域表示一个带权的无向图,设计一种算法的表示 C语言中临界矩阵转换为双向链域表示一个带权的无向图,设计一种算法的表示 解决方案 相当于图的遍历,首先根据邻接矩阵构造节点,然后依次把边添加到图中.

C语言解决螺旋矩阵算法问题的代码示例_C 语言

赶集网校招就采用了螺旋输出矩阵作为程序题,要求将矩阵螺旋输出如: 图中6*6矩阵线条所示为输出顺序,如果输出正确的话应该输出1~36有序数字.  我想的是这么做的: #include <stdio.h> //#define LEN 1 //#define LEN 2 //#define LEN 3 #define LEN 4 void printClock(int a[][LEN]){//输出函数 int t; int i = 0, m = 0; int j = LEN, n = LEN; w

c语言中的冒泡排序算法

问题描述 c语言中的冒泡排序算法 直接上代码,图: #include #include #include typedef struct{ int*pt; int cur; int len; }intArr; void bubblesort(intArr*ia){ int i,j,t,n=ia->cur; for(i=n;i>2;i--) for(j=1;j if(ia->pt[j]>ia->pt[j-1]){ t=ia->pt[j-1]; ia->pt[j-1]=

bm算法-模式匹配中的BM算法的C语言源代码

问题描述 模式匹配中的BM算法的C语言源代码 用c实现BM算法,匹配字符串和匹配文本都是手动输入,然后输出是否在匹配文本中找到匹配字符串,结果一定要正确没bug.

《数据结构与算法:Python语言描述》一1.3算法和算法分析

1.3算法和算法分析 本节集中讨论算法的问题,特别是算法的性质及其分析技术. 1.3.1问题.问题实例和算法 在考虑计算问题时,需要清晰地区分问题.问题实例和算法三个概念,并理解它们之间的关系,这就是本小节讨论的内容.三个基本概念考虑一个计算问题时,需要注意到三个重要概念:问题:一个问题W是需要解决(需要用计算求解)的一个具体需求.例如判断任一个正整数N是否为素数,求任一个方形矩阵的行列式的值等.虽然可以严格定义"问题"的概念,但在这里还是想依靠读者的直观认识.总而言之,现实世界中存在

c语言-C语言文件/哈夫曼树/算法/二叉树

问题描述 C语言文件/哈夫曼树/算法/二叉树 在一个函数中,下面这两行运行无错误 fp=fopen("CodeFile.dat","wb"); fwrite(HC[i],sizeof(char),strlen(HC[i])+1,fp); //其中HC的类型是char ** //然后在另外一个函数中加入 fp=fopen("CodeFile.dat","rb"); for(int i=1;i<=n;i++) fread(H

C语言实现二叉树遍历的迭代算法_C 语言

本文实例讲述了C语言实现二叉树遍历的迭代算法,是数据结构算法中非常经典的一类算法.分享给大家供大家参考. 具体实现方法如下: 二叉树中序遍历的迭代算法: #include <iostream> #include <stack> using namespace std; struct Node { Node(int i, Node* l = NULL, Node* r = NULL) : item(i), left(l), right(r) {} int item; Node* le

统计分析-r语言如何按百分位数对矩阵进行分组

问题描述 r语言如何按百分位数对矩阵进行分组 我有各省GDP数据,求的了百分位数,现在需要利用百分位数将所有地区分为3组 并分别利用参数检验和非参数检验方法来分析相邻两组之间gdp有无显著差异,求教高手 pcode name gdp 11 北京 2.133 12 天津 1.5722 13 河北 2.9421 14 山西 1.2759 15 内蒙 1.7769 21 辽宁 2.86 22 吉林 1.3803 23 黑龙 1.5039 31 上海 2.356 32 江苏 6.51 33 浙江 4.0

c语言编程-如何用C语言实现linux中的ll命令?

问题描述 如何用C语言实现linux中的ll命令? 如何用C语言实现linux中的ll命令?大师能给个完整的代码吗?最好有些注释.(我C语言学的不怎么好,害怕看不懂.) 解决方案 C语言实现的linux下ls命令linux "ll" 命令实现在Linux中, 用C语言简单实现chmod命令 解决方案二: 获取文件属性:http://www.cnblogs.com/hnrainll/archive/2011/05/11/2043361.html 遍历文件夹:http://blog.csd