Task 4.4二维环形数组求最大子矩阵之和
任务:
- //二维环形数组求最大子矩阵
- //刘子晗 2015/4/22
- #include<iostream>
- #include<time.h>
- using namespace std;
- void main()
- {
- int m, n, a[][], b[][],i, j ;
- cout << "请输入矩阵的行数和列数:" << endl;
- cin >> m >> n;
- srand((unsigned)time(NULL));
cout << "产生的随机数组为:" << endl;
- for (i = ; i < m; i++)
- {
- for (j = ; j < n; j++)
- {
- a[i][j] = rand() % - ;
- cout << a[i][j] << " ";
- }
- cout << endl;
- }//输出随机产生的矩阵
- int max = a[][];
- for (i = ; i < m ; i++)
- {
- for (j = ; j < n; j++)
- {
- a[i][j + n] = a[i][j];
- }
- }//对二维数组进行扩展,横向延长一倍
- cout << "扩展后环形数组为:" << endl;
- for (i = ; i < m; i++)
- {
- for (j = ; j < *n-; j++)
- {
- cout << a[i][j] << ' ';
- }
- cout << endl;
- }//输出扩展之后的新数组
- for (i = ; i < ; i++)
- {
- b[][] = a[][];
- for (j = ; j < *n -; j++)
- {
- if (a[][j - ] < )
- {
- b[][j] = a[][j];
- }
- else
- {
- b[][j] = b[][j - ] + a[][j];
- }
- }
- }//对第一行的数作为一个数组求其最大连续子数组之和
- for (i = ; i < m; i++)
- {
- for (j = ; j < ; j++)
- {
- if (a[i - ][] < )
- {
- b[i][] = a[i][];
- }
- else
- {
- b[i][] = b[i - ][] + a[i][];
- }
- }
- }//对第一列的数作为一个数组,求其连续子数组的最大和
- for (i = ; i<m; i++)
- {
- for (j = ; j<*n-; j++)
- {
- if (b[i - ][j - ]<)
- {
- if (b[i - ][j] >= && b[i][j - ] >= )
- {
- if (b[i][j - ] >= b[i - ][j])
- {
- b[i][j] = b[i][j - ] + a[i][j];
- }
- else
- {
- b[i][j] = b[i - ][j] + a[i][j];
- }
- }
- else if (b[i - ][j] >= && b[i][j - ] <= )
- {
- b[i][j] = b[i - ][j] + a[i][j];
- }
- else if (b[i - ][j] <= && b[i][j - ] >= )
- {
- b[i][j] = b[i][j - ] + a[i][j];
- }
- else
- {
- b[i][j] = a[i][j];
- }
- }
- else
- {
- if (b[i - ][j] >= && b[i][j - ] >= )
- {
- b[i][j] = a[i][j] + b[i - ][j] + b[i][j - ] - b[i - ][j - ];
- }
- else if (b[i - ][j] >= && b[i][j - ] <= )
- {
- b[i][j] = a[i][j] + b[i - ][j] - b[i - ][j - ];
- }
- else if (b[i - ][j] <= && b[i][j - ] >= )
- {
- b[i][j] = a[i][j] + b[i][j - ] - b[i - ][j - ];
- }
- else
- {
- b[i][j] = a[i][j];
- }
- }
- }
- }//求整个矩阵中从首个元素到当前元素的数组和的最大值,并将该值赋给当前地址
- cout << "子矩阵的和数组为:" << endl;
- for (i = ; i<m; i++)
- {
- for (j = ; j< * n - ; j++)
- {
- cout << b[i][j] << " ";
- }
- cout << endl;
- }//输出新生成的和数组
- cout << endl;
- for (i = ; i<m; i++)
- {
- for (j = ; j< * n - ; j++)
- {
- if (b[i][j]>max)
- {
- max = b[i][j];
- }
- }
- }//求数组中的最大元素
- cout << "最大子矩阵和为:" << max << endl;
- }
3.结果截图:
4.总结:(1)再一次感觉到拆分问题的重要性,无论题目有多复杂,当拥有可以拆分问题的能力的时候,一一击破然后再将其有机地组合起来,一切问题都会迎刃而解;
(2)题目在一步一步地增加难度的时候,如果能把之前的每个相对简单的程序都弄明白之后,组合成的难题反而却是非常简单的。所以每次完成一个程序一定要完全把它想清楚,非以方便以后去使用其中的内容和思想;
(3)要善于总结,每一次总结回顾总能发现不一样的问题,得到不一样的体会。
Task 4.4二维环形数组求最大子矩阵之和的更多相关文章
- Codeforces Round #369 (Div. 2) A. Bus to Udayland【字符串/二维字符数组求连起来的座位并改为其他字符】
A. Bus to Udayland time limit per test 2 seconds memory limit per test 256 megabytes input standard ...
- 计算机二级-C语言-程序填空题-190109记录-对二维字符串数组的处理
//给定程序,函数fun的功能是:求出形参ss所指字符串数组中最长字符串的长度,将其余字符串右边用字符*补齐,使其与最长的字符串等长.ss所指字符串数组中共有M个字符串,且串长<N. //重难点 ...
- PHP二维关联数组的遍历方式
采用foreach循环对二维索引数组进行遍历,相对来讲速度更快,效率更高,foreach循环是PHP中专门用来循环数组的.实例也相对简单,多加练习,想清楚程序运行逻辑即可. <?php $arr ...
- C++ 指针二维数组, C++二维指针数组笔记
C++ 二维动态数组 一. 已知第一维 #include <iostream> using namespace std; int main(int argc, char const *ar ...
- 子串查询(二维前缀数组) 2018"百度之星"程序设计大赛 - 资格赛
子串查询 Time Limit: 3500/3000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total Subm ...
- 二维字符数组利用gets()函数输入
举例: ][]; ;i<;i++) gets(a[i]); a是二维字符数组的数组名,相当于一维数组的指针, 所以a[i]就相当于指向第i个数组的指针,类型就相当于char *,相当于字符串.
- 分配一维动态数组or 二维动态数组的方法以及学习 new 方法or vector
先来个开胃菜 // 使用new动态分配存储空间 #include<iostream> using std::cout; int main() { // 第1种方式 int *a=new i ...
- go 动态数组 二维动态数组
go使用动态数组还有点麻烦,比python麻烦一点,需要先定义. 动态数组申明 var dynaArr []string 动态数组添加成员 dynaArr = append(dynaArr, &quo ...
- 【C/C++】二维数组的传参的方法/二维字符数组的声明,使用,输入,传参
[问题] 定义了一个子函数,传参的内容是一个二维数组 编译提示错误 因为多维数组作为形参传入时,必须声明除第一位维外的确定值,否则系统无法编译(算不出偏移地址) [二维数组的传参] 方法一:形参为二维 ...
随机推荐
- 【VSC】我安装了哪些扩展插件
Nodejs gitk —— 版本实时比对 Debugger for Chrome —— 让 vscode 映射 chrome 的 debug功能,静态页面都可以用 vscode 来打断点调试. ...
- fio是如何运行的?
本文主要介绍fio是如何运行的,并且以单线程.单job为例 fio的入口在fio.c中的main函数,下面列出了main函数,此处只出示了一些调用的关键函数 int main(int argc, ch ...
- dataTable配置项说明
Datatables是一款jquery表格插件.它是一个高度灵活的工具,可以将任何HTML表格添加高级的交互功能. 官网地址:https://datatables.net/ 中文说明地址:http:/ ...
- Linux服务-ftp
目录 1. ftp简介 2. ftp架构 3. ftp数据连接模式 4. 用户认证 5. vsftpd 5.1 vsftpd安装 5.2 vsftpd配置 5.3 vsftpd实验配置 5.3.1 安 ...
- 用NI的数据采集卡实现简单电子测试之4——半导体温度传感器
本文从本人的163博客搬迁至此. 为了展示NImax(Measurement & Automation explorer)的强大配置功能,做了一个半导体温度传感器测试的示例. 一.半导体温度传 ...
- IceStorm示例运行步骤
又一次忘了,记下: 1.启动IceStorm服务,输入:icebox --Ice.Config=config.icebox 启动IceStorm服务.2.消息接收:开启另一个命令行窗口,Subscri ...
- 生死系列--SongXingZhi
SongXingZhi,我上中专时的同学,任劳动委员,湖北随州人.其实在上学以及毕业后,我们俩没什么交往,也没说过几句话. 印象比较深的一次是在上什么课时,老师拖堂了 ,他直接从课桌上翻过来,从后门出 ...
- JavaWeb基础——JSON
一.JSON是什么? JSON(JavaScript Object Notation).轻量级数据交换格式. JSON的后缀名:.json JSON的MINE类型:application/json 二 ...
- JavaScript总结(四)
详解BOM(浏览器对象模型(Browser Object Model)) ✍ Window对象方法 方法 描述 alert() 显示带有一段消息和一个确认按钮的警告框 blur() 把键盘焦点从顶层窗 ...
- 【HNOI2013】数列
题面 题解 设\(\{a_n\}\)为差分数组,可以得到柿子: \[ \begin{aligned} ans &= \sum_{a_1 = 1} ^ m \sum_{a_2 = 1} ^ m ...