A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 张锦萍 中级黑马   /  2012-3-23 09:50  /  1026 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

输入一个已经按升序排序过的数组和一个数字,在数组中查找两个数,使得它们的和正好是输入的那个数字。要求时间复杂度是O(n)。
例如输入数组1、2、3、4、7、11、15和数字15。由于4+11=15,因此输出4和11。

1 个回复

倒序浏览
我自己写了一个
public class FindNum {

        /**
         * @param args
         */
        public static void main(String[] args) {
                int[] intArr = {1,2,3,4,7,11,15};
                int sum =15;
               
                int start;
                int end;
                int i=0;
                int j=intArr.length-1;               
                while(true){
                        start = intArr[i];
                        end = intArr[j];
                       
                        if((start+end)<sum){
                                i++;
                        }else if((start+end)==sum){
                               
                                break;                               
                        }else if((start+end)>sum){
                               
                                j--;
                        }
                }
                System.out.println(start+","+end);

        }

}
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马