题解 | #和为S的两个数字#

和为S的两个数字

http://www.nowcoder.com/practice/390da4f7a00f44bea7c2f3d19491311b

双指针

注意:
1、双指针调整位置
2、更新最小乘积

class Solution {
public:
    vector<int> FindNumbersWithSum(vector<int> array,int sum) {
        int start =0;
        int end = array.size()-1;
//         std::vector< std::pair<int, int> > map_of_eles;
        std::pair<int, int> res1{0,0};
        int tmp_min = INT_MAX;
        while(start < end){
            int tmp = array[start] + array[end];
            if(tmp > sum){
                end--;
            }
            else if(tmp < sum){
                start++;
            }
            else{        // 相等
                if(array[start]*array[end]<tmp_min){
                    tmp_min = array[start] * array[end];
                    res1 = {array[start], array[end]};

                }
                start++;
                end--;

            }
        }

        std::vector<int> res;
        if(res1.first ==0 && 0== res1.second){
            return res;
        }

        res.push_back(res1.first);
        res.push_back(res1.second);


        return res;
    }
};
全部评论

相关推荐

努力学习的小绵羊:我反倒觉得这种挺好的,给不到我想要的就别浪费大家时间了
点赞 评论 收藏
分享
11-14 17:28
已编辑
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务