数组练习2

 结对开发:张哲  张晓菲

题目:返回一个数组中子数组最大和,数组可以首尾相连。

一、实验思路

   本次实验在第一次的基础上增加了一些难度,数组可以首尾相连组成一个环,我们两个经过思考和讨论后得到一个方法:

1、在对环的特殊性研究后,我们可以将一个环拆成一个链,即:5 -1 3 3 拆成5 -1 3 3 5 -1 3 这个环每次从开始位置四个四个组队,即5 -1 3 3 、-1 3 3 5、3 3 5 -1、3 5 -1 3 ,然后利用for循环,计算其最大子数组和,这样即可以达到一个环所呈现的结果。

2、对于记录位置这个问题,我们定义了cstart start end三个变量来表示,cstart记录每次循环最大子数组和的位置,start记录最终最大子数组和的位置,end则记录最大子数组和终点的位置。

二、程序代码

 1 //返回一个整数数组中最大子数组的和
 2 //有正数、有负数、数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和、将数组首尾相连、返回最大子数组的位置
 3 //张哲、张晓菲 2016/3/22
 4 
 5 #include<iostream>
 6 using namespace std;
 7 
 8 #define N 10000
 9 int main()
10 {
11     int num, arr[N];
12     int sum = 0;
13     cout << "请输入数组元素个数:";
14     cin >> num;
15     cout << "请输入数组元素的值:";
16     for (int i = 0; i<num; i++)//输入环状数组的元素值
17     {
18         cin >> arr[i];
19     }
20     for (int i = num; i<(2 * num - 1); i++)//将环抻直,例如环状数组值原先为[A,B,C,D],那么抻直之后为[A,B,C,D,A,B,C]
21     {
22         arr[i] = arr[i%num];
23     }
24     cout << "环抻直之后的数组相当于:" << endl;
25     for (int i = 0; i<(2 * num - 1); i++)
26     {
27         cout << arr[i] << " ";
28     }
29     cout << endl;
30 
31     int max = arr[0];
32     int end, start, cstart;//end为结束位置 start为起始位置
33 
34     //求子数组最大和
35     for (int j = 0; j<num; j++)
36     {
37         sum = 0;
38         for (int i = j; i<j + num; i++)
39         {
40             if (sum <= 0)
41             {
42                 sum = arr[i];
43                 cstart = i;//当前最大子数组的起始位置
44             }
45             else
46                 sum = sum + arr[i];
47             if (sum>max)
48             {
49                 max = sum;
50                 start = cstart;
51                 end = i;//最大子数组的终止位置
52             }
53         }
54     }
55     cout << "子数组和的最大值为:" << max << endl;
56     cout << "最大子数组的起始位置为环抻直后的第" << start + 1 << "个元素,结束位置为环抻直后的第" << end+1 << "个元素。" << endl;
57     return 0;
58 }

三、实验结果截图

结果中给出了拆开后的数组,数组的位置从1开始,数组位置记录的是拆开后的位置。

四、时间记录日志

日期开始时间结束时间中断时间(min)净时间(min)活动备注

3月21号

星期一

14:0015:5010(课间)100听课软件工程
 20:00 22:00 120编程一维数组1

3月22号

星期二

19:5020:40050编程一维数组1

3月23号

星期三

15:0014:0010(休息)50看书构建之法
 20:0021:150(休息)75编程一维数组1

3月24号

星期四

14:0015:5010(课间)100听课软件工程
 20:3022:0010(休息)80编程一维数组2

3月25号

星期五

16:3017:000(休息)70编程一维数组2
 21:0022:00060编程一维数组2

3月26号

星期六

9:0010:00080编程

一维数组2程序进行

修改、写博客

转载于:https://www.cnblogs.com/zz0906/p/5322030.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/357461.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java 8中最快的垃圾收集器是什么?

OpenJDK 8具有几种垃圾收集器算法&#xff0c;例如Parallel GC &#xff0c; CMS和G1 。 哪一个最快&#xff1f; 如果默认的GC从Java 8中的并行GC更改为Java 9中的G1&#xff08;当前建议&#xff09;&#xff0c;将会发生什么&#xff1f; 让我们对其进行基准测试。 基准方法…

如何做好内容策划并完成一篇合格的深度文?

目录 常见的策划方案有哪些类型? 如何思考策划方向? 如何确定内容形式?

在计算机硬件中mo是指,计算机导论 - [课件]第2章 计算机系统的硬件.ppt

计算机导论 - [课件]第2章 计算机系统的硬件微操作控制部件(MOCU)可有下列两种实现方案&#xff1a; 组合逻辑控制 微程序控制 CPU 主存储器 I/O接口 DMA控制器 I/O设备 总线 交换数据 ① ② ④ ③ 3. 直接存储器存取方式DMA P83 上一页 返 回 下一页 * 教学小结 常见的输入输出…

System.Timers.Timer 嵌套 System.Windows.Forms.Timer的问题

如题“System.Timers.Timer 嵌套 System.Windows.Forms.Timer的问题”&#xff0c;最近在项目中在类uc_Map中启用了System.Timers.Timer&#xff0c;并在Timer的Timer_Elapsed方法中需要启动或停止GMapMarkerDirection markerPlane类中的System.Windows.Forms.Timer&#xff0c…

【粉丝需求】如何把一个前端网页都搞下来?

一般比较简单的就是展示型网站,这类网站 最好仿制,如果带后台的不太好获取完整后台代码,但是搞一下前端代码还是可以的。一般前端不管用什么框架,基础元素由html+css+javaScript组成。 声明:本文仅仅提供一种思路,如有对站点侵权的地方,请联系博主删除。 我用的是HB-X,…

韦冬雪计算机应用,捕获效应下RFID防碰撞算法的研究与应用

摘要&#xff1a;作为物联网核心技术之一的射频识别(Radio Frequency Identification,RFID)技术,其应用市场正随着物联网的普及而拓宽.阅读器和标签是RFID系统的重要组成部分,阅读器负责发出查询命令,标签负责响应命令.当多个标签同时向同一个阅读器发送响应命令时会发生标签碰…

九、其他常用命令

一、挂载命令 可以理解为windows当中的分配盘符操作 1.查询与自动挂载 [rootlocalhost ~]# mount #查询系统中已经挂载的设备 [rootlocalhost ~]# mount –a #依据配置文件/etc/fstab的内容&#xff0c;自动挂载一遍 只要按照对应的格式将相应的分区添加到list中&#xff0c;那…

王凯1987计算机系,计算机科学与技术系王凯:付出总有回报

首先&#xff0c;我真的很高兴能拿到这个奖&#xff0c;毕竟&#xff0c;这是对我自己大一这半年付出的一种肯定&#xff0c;也是对今后学习的很大鼓励。我想&#xff0c;学校之所以设立奖学金&#xff0c;真正的目的也正如此吧。听到这个信息时&#xff0c;我感到惊喜又意外&a…

【ECharts系列|01入门】 从入门到天黑【入门级教程实战】

ECharts 是一个使用 JavaScript 实现的开源可视化库&#xff0c;涵盖各行业图表&#xff0c;满足各种需求。 ECharts 遵循 Apache-2.0 开源协议&#xff0c;免费商用。 ECharts 兼容当前绝大部分浏览器&#xff08;IE8/9/10/11&#xff0c;Chrome&#xff0c;Firefox&#xff0…

【LeetCode】1. Two Sum

题目&#xff1a; Given an array of integers, return indices of the two numbers such that they add up to a specific target. You may assume that each input would have exactly one solution. 从给定的一个整数数组中找出两个数&#xff0c;使得它们的和为target&…

Java开发人员应了解的JVM流行语

本文将与您分享一些JVM“流行语”&#xff0c;它们对于Java开发人员在执行任何JVM性能和垃圾回收调优之前理解和记住非常重要。 本文末尾还提供了一些技巧&#xff0c;包括一些高级性能调优最佳实践。 将来的文章中将探讨有关Oracle HotSpot并发GC收集器&#xff08;例如CMS和G…

计算机制图笔记本需要什么配置,绘图笔记本需要什么配置?

ACER 宏碁型号 EX4630ZG-421G25MnCPU平台 Intel平台速度 T4200 2.00GHz系统总线 800MHz二级缓存 1MB屏幕尺寸 14寸类型 WXGA显示芯片 NVIDIA GeForce 9300M GS 独立显示芯片显存容量 独立256MB内存容量 1GB速度 DDR2硬盘容量 250G转速 5400转/分钟接口类型 SATA串行光存储 DVDR…

【ECharts系列|02可视化大屏】 舆情分析,人口分析及警情警力活动情况的实现【上篇】

简介&#xff1a;ECharts实现可视化大屏展示&#xff0c;包含人口分析&#xff0c;警情警力分析多张效果图&#xff0c; 完整的htmlcssjsimg:https://download.csdn.net/download/weixin_41937552/16361615 项目结构&#xff1a; activity.html <!doctype html> <met…

算法属于计算机服务还是软件,第06讲 服务器软件设计的算法和问题

第06讲 服务器软件设计的算法和问题本文由&#xff32;&#xff49;&#xff43;&#xff48;&#xff41;&#xff52;&#xff44;&#xff10;&#xff10;&#xff17;&#xff3f;&#xff4c;&#xff49;&#xff4e;贡献&#xff50;&#xff50;&#xff54;&#xff…

那些遇到的position-fixed无效事件

本篇文章由&#xff1a;http://xinpure.com/position-fixed-encountered-an-invalid-event/ 第一次无效事件 事件主角: transform 应用环境: Chrome/FireFox 事件回顾: 这是在使用 iscroll js滚动库的时候&#xff0c;遇到的问题 当时的需求是需要在滚动到一定的距离的时候&…

spring rmi_Spring远程支持和开发RMI服务

spring rmiSpring远程支持简化了启用远程服务的开发。 当前&#xff0c;Spring支持以下远程技术&#xff1a;远程方法调用&#xff08;RMI&#xff09;&#xff0c;HTTP调用程序&#xff0c;Hessian&#xff0c;Burlap&#xff0c;JAX-RPC&#xff0c;JAX-WS和JMS。 远程方法调…

计算机dos通讯,PC双机通信DOS

《PC双机通信DOS》由会员分享&#xff0c;可在线阅读&#xff0c;更多相关《PC双机通信DOS(64页珍藏版)》请在人人文库网上搜索。1、1 第第9 9章章 串行通信接口串行通信接口 主要内容&#xff1a;主要内容&#xff1a;1 1、串行传送的基本概念、串行传送的基本概念 2 2、串行通…

用Paint Tool SAI绘制漫画

漫画绘图软件 Paint Tool SAI是一个来自日本的小巧的漫画辅助绘图软件&#xff0c;只有11M大小。 这个没有任何现成的模板和组件&#xff0c;只能自己一笔一笔的话&#xff0c;画笔、图层等功能与Photoshop类似&#xff0c;但没有PS其它大量功能&#xff0c;因此操作更加便捷&a…

【ECharts系列|02可视化大屏】 舆情分析,人口分析及警情警力活动情况的实现【下篇】

简介&#xff1a;ECharts实现可视化大屏展示&#xff0c;包含人口分析&#xff0c;警情警力分析多张效果图&#xff0c; 完整的htmlcssjsimg:https://download.csdn.net/download/weixin_41937552/16361615 上一篇&#xff1a;【ECharts系列|02可视化大屏】 舆情分析&#xff0…

uts计算机博士,澳大利亚悉尼科技大学 (UTS) 招收2021/2022年 全奖博士生 (软件工程/人工智能方向)...

☞招收2022年第一学期入学&#xff0c;软件工程&#xff0c;人工智能方向csc博士生, 访问学生和全奖学生。学校介绍:澳大利亚悉尼科技大学(uts)座落于风景优美的悉尼市中心&#xff0c;毗邻darling harbour&#xff0c;中国城&#xff0c;悉尼歌剧院。uts是世界知名研究学府&am…