求已知集合中某两个或三个元素之和等于确定值问题 收藏
2009-09-13 23:22
302 查看
求已知集合中某两个或三个元素之和等于确定值问题 收藏
问题描述:
1、给定一个数组,该数组包含N个元素。我们想要确定是否存在两个数它们的和等于给定的数K。例如,如果输入是8,4,1,6而K是10,则答案为yes(4和6)。一个数可以被使用两次。
给出求解该问题的O(NlogN)算法。
2、1、给定一个数组,该数组包含N个元素。我们想要确定是否存在三个数它们的和等于给定的数K。例如,如果输入是8,4,1,6而K是13,则答案为yes(8和4和1)。一个数可以被使用两次或三次。
给出求解该问题的O(N2)算法。
解题思路:
1,首先用快速排序或并归排序将已知集合排序(nlogn),然后用类似于快速排序的方法操作,代码如下:
//L是已经排序好的数组
bool f( int *L, int len, int sum ){
int i=0, j=len-1;
while( i<j ){ if( L[i]+L[j]==sum )
return true;
else
if( L[i]+L[j]>sum )
--j;
else
++i;
}
return false;
}
2,先将数组按递增进行快速排序,快速排序的复杂度是O(nlogn)的。
还是用问题1的方法,我们从问题1的解决方法中可以看到:
如果数组是有序的,那么确定是否存在两个数它们的和等于给定的数sum的算法的时间复杂度是O(n)的(n为数组长度)。
现在,我们要找确定是否存在L[i]+L[j]+L[k]=sum。 (1)
不妨令L[i] <=L[j] <=L[k]
我们现在将(1)式变为: L[i]+L[j]=sum-L[k]
令SUM=sum-L[k]。
现在,容易看到SUM的值只可能有n个,而对每一个SUM,我们确定是否存在两个数它们的和等于给定的数SUM的时间复杂度是O(n)的,于是,总的时间复杂度是:
O(nlogn+n^2)=O(n^2)。
http://topic.csdn.net/u/20080314/21/7fff8e74-ed62-4d34-90c9-8d4e05bc52a4.html
问题描述:
1、给定一个数组,该数组包含N个元素。我们想要确定是否存在两个数它们的和等于给定的数K。例如,如果输入是8,4,1,6而K是10,则答案为yes(4和6)。一个数可以被使用两次。
给出求解该问题的O(NlogN)算法。
2、1、给定一个数组,该数组包含N个元素。我们想要确定是否存在三个数它们的和等于给定的数K。例如,如果输入是8,4,1,6而K是13,则答案为yes(8和4和1)。一个数可以被使用两次或三次。
给出求解该问题的O(N2)算法。
解题思路:
1,首先用快速排序或并归排序将已知集合排序(nlogn),然后用类似于快速排序的方法操作,代码如下:
//L是已经排序好的数组
bool f( int *L, int len, int sum ){
int i=0, j=len-1;
while( i<j ){ if( L[i]+L[j]==sum )
return true;
else
if( L[i]+L[j]>sum )
--j;
else
++i;
}
return false;
}
2,先将数组按递增进行快速排序,快速排序的复杂度是O(nlogn)的。
还是用问题1的方法,我们从问题1的解决方法中可以看到:
如果数组是有序的,那么确定是否存在两个数它们的和等于给定的数sum的算法的时间复杂度是O(n)的(n为数组长度)。
现在,我们要找确定是否存在L[i]+L[j]+L[k]=sum。 (1)
不妨令L[i] <=L[j] <=L[k]
我们现在将(1)式变为: L[i]+L[j]=sum-L[k]
令SUM=sum-L[k]。
现在,容易看到SUM的值只可能有n个,而对每一个SUM,我们确定是否存在两个数它们的和等于给定的数SUM的时间复杂度是O(n)的,于是,总的时间复杂度是:
O(nlogn+n^2)=O(n^2)。
http://topic.csdn.net/u/20080314/21/7fff8e74-ed62-4d34-90c9-8d4e05bc52a4.html
相关文章推荐
- 求已知集合中某两个或三个元素之和等于确定值问题
- 判断集合S中是否存在两个其和等于x的元素
- 给出一个实数集合和一个实数,怎样判断集合中是否存在两个和等于该实数的元素
- 算法导论——集合S是否存在两个元素相加之和等于x
- 已知两个链表A和B分别表示两个集合,其元素递增排列。请设计算法求出两个集合A和B的差集(即仅由在A中出现而不在B中出现的元素所构成的集合),并以同样的形式存储,同时返回该集合的元素个数。
- 确定集合中是否存在两个其和刚好为X的元素?
- 题目:请给出一个运行时间为Θ(nlgn)的算法,使之能在给定一个由n个整数构成的集合S和另一个整数x时,判断出S中是否存在有两个其和等于x的元素。
- 描述一个运行时间为O(nlgn)的算法,使之能在给定一个由n个整数构成的集合S和另一个整数 X 时,判断出S中是否存在有两个其和刚好等于 X 的元素。
- 题目1.请给出一个运行时间为O(nlgn)的算法,使之能在给定一个由n个整数构成的集合S和另一个证书x时,判断出S中是否存在有两个其和等于x的元素。
- 描述一个运行时间为Θ(nlgn)的算法,给定n个整数的集合S和另一个整数x,该算法能确定S中是否存在两个其和刚好为x的元素
- 2.3-7 描述一个运行时间为Θ(nlgn)的算法,给定n个整数的集合S和另一个整数x,该算法能确定S中是否存在两个其和刚好为x的元素
- 算法入门---判断集合S中是否存在两个其和等于x的元素
- 【算法导论学习-005】整数集合S中是否存在两个数等于给定的一个整数
- 两个集合有共同元素,其中一个集合删除两个集合共同的元素
- 对N各集合中的任意元素进行排列组合问题
- Javascript中两个等于号和三个等于号的区别(==/===)
- js中两个等于号和三个等于号的区别
- 给定一个集合和一个正整数c,判定是否存在该集合的子集,使其所有元素的和等于给定的正整数c?
- 查找集合中两个最大的元素
- 用for循环来删除ArrayList集合中的所有元素所遇到的问题