一道算法题,看看大家的思路

简介:

题目描述:有31,-41,59,26,-53,58,97,-93,-23,84十个数。SUM(N,M)表示从第N个数到到第M个数的和。例如:SUM(2,3)=-41+59=18。问:最大的和是多少?对应的N和M是多少?

  这个题目并不难,实现的方法多种多样。最坏的算法,遍历所有的情况,求出最大和。

  我在这儿提一个算法的思路,不是最优的,主要是讲解这个算法的。

  模拟生物算法(谢谢装配脑袋指正,这应该是遗传算法)。

  根据题目,构造生物S,生物S有三个属性N、M、V。N表示开始的下标,M表示结束的下标,和题目中的定义一样。V表示从第N个数到第M个数的和,V和N、M是相关的。因此,可以用S(N,M)表示这个生物。

  先期构造10个这样的生物。称为第一代。

  生物有两个特性,繁衍性和变异性。

  繁衍性:生物S1(N1,M1)和生物S2(N2,M2)繁衍的后代为生物S3(N1,M2)和生物S4(N2,M1)

  变异性:生物S1(N1,M1)产生变异,得到S2(N2,M1)或者是S2(N1,M2)

  第一代生物通过繁衍和变异得到10个后代(繁衍和变异的比例自定)。这样一共有20个生物。然后这20个生物采用优胜劣汰的方法,保留10个V最大的生物,淘汰10个生物。这称为自然选择的一代。

  模拟大自然的自然选择,通过初期的10个生物,经过5代的自然选择,基本上就能得到最优解。

 

  模拟生物算法(遗传算法),就是利用繁衍和变异以及优胜劣汰,保留最优的生物,得到最优解。在某些实际问题中,能达到不错的效果。不过模拟生物算法(遗传算法)不能保证一定能在最优解收敛,但基本上能保证在局部最优解上实现收敛。

 

  本题用模拟生物算法(遗传算法)并不是最合适,我只是利用这道题简单介绍模拟生物算法的基本思想。

  欢迎各位提出本题的最优算法,空间上的最优算法、时间上的最优算法。


  本文转自万仓一黍博客园博客,原文链接:http://www.cnblogs.com/grenet/archive/2010/01/27/1657501.html,如需转载请自行联系原作者


相关文章
|
存储 算法 Java
【算法练习】有趣的括号匹配问题(思路+ 图解 +优化)基于java实现
1.题目描述 小洛看着一堆只包含’(‘和’)‘的括号序列犯愁了,小洛想知道这串序列里最长正确匹配的序列长度是多少,你能帮帮小洛吗?
【算法练习】有趣的括号匹配问题(思路+ 图解 +优化)基于java实现
|
机器学习/深度学习 人工智能 算法
从频度引发的c语言多重for循环乃至编写算法思路的思考
首先需要声明的是,笔者是一名有C语言基础并正在为考研而复习数据结构的大学生,本篇文章中的for循环代码来自于清华大学严蔚敏教授出版的《数据结构》。 本篇博客适用于初学者理解C语言for循环,多重for循环、数据结构频度、线性代数矩阵等知识点。 整篇文章从频度开始,讲述两个矩阵相乘算法,最后讲述整个算法的设计原理
211 4
从频度引发的c语言多重for循环乃至编写算法思路的思考
|
前端开发 容器 Docker
前端工程师学 docker 看这个就够了
虽然是做前端的,但是有时候也会做一些和前端不太相关的事儿。 最近在工作中用到了 docker,配合运维同学为自己的node项目创建了一个 docker 镜像。
143 1
前端工程师学 docker 看这个就够了
|
算法 调度
【Day31】力扣算法(超详细思路+注释)[1441. 用栈操作构建数组 ] [621. 任务调度器]
学习力扣算法(超详细思路+注释)[1441. 用栈操作构建数组 ] [621. 任务调度器]。
291 0
【Day31】力扣算法(超详细思路+注释)[1441. 用栈操作构建数组 ] [621. 任务调度器]
|
算法 索引
【Day28】力扣算法(超详细思路+注释) [1790. 仅执行一次字符串交换能否使两个字符串相等 ] [328. 奇偶链表 ][148. 排序链表]
了解(超详细思路+注释) [1790. 仅执行一次字符串交换能否使两个字符串相等 ] [328. 奇偶链表 ][148. 排序链表]。
129 0
【Day28】力扣算法(超详细思路+注释) [1790. 仅执行一次字符串交换能否使两个字符串相等 ] [328. 奇偶链表 ][148. 排序链表]
|
算法 测试技术
【Day27】 LeetCode算法刷题(思路+注释)[801. 使序列递增的最小交换次数 ]
了解算法刷题(思路+注释)[801. 使序列递增的最小交换次数 ]。
127 0
【Day27】 LeetCode算法刷题(思路+注释)[801. 使序列递增的最小交换次数 ]
|
算法
【Day24】 LeetCode算法题 (注释详细+解题思路)[43. 字符串相乘 ] [1800. 最大升序子数组和]
学习 (注释详细+解题思路)[43. 字符串相乘 ] [1800. 最大升序子数组和]。
134 0
【Day24】 LeetCode算法题 (注释详细+解题思路)[43. 字符串相乘 ] [1800. 最大升序子数组和]
|
算法
【Day19】LeetCode算法刷题(附带解题思路、代码注释详细) 【777. 在LR字符串中交换相邻字符】 【54. 螺旋矩阵】
学习了解附带解题思路、代码注释详细) 【777. 在LR字符串中交换相邻字符】 【54. 螺旋矩阵】。
124 0
【Day19】LeetCode算法刷题(附带解题思路、代码注释详细) 【777. 在LR字符串中交换相邻字符】 【54. 螺旋矩阵】
|
算法 索引
【Day15】算法刷题(解题思路+详细注释)[面试题 17.09. 第 k 个数 ][424. 替换后的最长重复字符 ][438. 找到字符串中所有字母异位词 ]
了解[面试题 17.09. 第 k 个数 ][424. 替换后的最长重复字符 ][438. 找到字符串中所有字母异位词 ]。
183 0
【Day15】算法刷题(解题思路+详细注释)[面试题 17.09. 第 k 个数 ][424. 替换后的最长重复字符 ][438. 找到字符串中所有字母异位词 ]
|
算法 C++
【牛客刷题-算法】加精 | 合并两个有序的链表 - 从思路设计、bug排除到最终实现的全过程
【牛客刷题-算法】加精 | 合并两个有序的链表 - 从思路设计、bug排除到最终实现的全过程
127 0
【牛客刷题-算法】加精 | 合并两个有序的链表 - 从思路设计、bug排除到最终实现的全过程