一 问题描述 和为n的正数序列,比如求合为15的正数连续序列,则有以下序列满足 12345 == 456 == 78 解题思路: 设置一个small =1 ,big=2 求 sum = [small , big] 若sum 大于15 ,则small左移,相当于去掉最小值。 若sum 小于15 ,则big 右移, 相当于增加最大值。 扩展如下: 若在一个已经排序的序列中,求两个元素之和为定值的元素。 可以使用left ,right分别表示,序列中的首尾元素,若left+right 大于给定和,则right--,若小于则left++。 与此题的思路相似。
posted on 2011-05-19 13:46 kahn 阅读(241) 评论(0) 编辑 收藏 引用
Powered by: C++博客 Copyright © kahn