算法导论习题解答 2.3-7

2.3-7 请给出一个运行为Θ(nlgn)的算法(伪码),使之能在给定一个由n个整数构成的集合S和另一个整数x时,判断出S中是否存在有两个其和等于x的元素。

解:解题思路:先对集合S进行归并排序,然后新建一个数组S1,使得S1[i] = x S[i],再将两个数组并起来。如果在并的过程中发现有两个元素相等且两个元素一个来自S,一个来自S1,则可以确定S中存在有两个其和等于x的元素。

Find whether x exits

1Sort(S)

2for i <- 0 to Length(S) 1

3     do S1[i] <- x - S[i]

4for i <- 0 to Length(S) 1

5     do Merge( S,S1 ) 

6        if S[p] > S1[q]

7            S0[k] <- S[p]  p++ k++

8        if S[p] < S1[q]

9            S0[k] <- S[q]  q++ k++

10       if S[p] == S1[q]

11          return true

12return false        

在第一行进行排序时,时间代价为Θ(nlgn),后来的合并过程时间代价为Θ(n),总的时间代价为Θ(nlgn)

 

你可能感兴趣的:(数据结构,编程,C++,算法)