c++ - 一个算法:在极大的无序序列中寻找三个数和大于等于N的所有组合数量
PHP中文网
PHP中文网 2017-04-17 11:21:56
0
2
639

比如:1 4 2 5 9 中寻找大于6的组合

1 2 4
1 2 5
1 2 9
1 4 5
1 4 9
2 4 5
2 4 9
4 5 9

一共8个组合。

如果是自然数序列,可以先排序再找到最小的满足组合,接下来只需要复杂度为n的算法就可以得到结果。但是如果序列的值是离散的,使时间复杂度尽可能小的算法应该怎么考虑呢?

备注:
数值大于10^16

PHP中文网
PHP中文网

认证高级PHP讲师

全員に返信(2)
巴扎黑

能加能比较用你自己说的这个算法有什么问题吗?

いいねを押す +0
Ty80

不是自然数就不能排序了吗?数值大一点的话也可以排序的啊,并且复杂度只和你的数字个数有关啊

いいねを押す +0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート