5-剑指offer: 和为S的两个数字
题目描述
输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。
输出描述:
对应每个测试案例,输出两个数,小的先输出。
代码:
class Solution {
public:
    vector<int> FindNumbersWithSum(vector<int> array,int sum) {
        vector<int> result;
        if (array.size() <2)
            return result;
        int left=0, right=array.size()-1;
        int num_a, num_b, product=array[right] * array[right];
        bool valid = false;
        while(left < right) {
            if(array[left] + array[right] < sum) {
                left++;
            }else if(array[left] + array[right] > sum) {
                right--;
            } else if(array[left] + array[right] == sum && array[left] * array[right] < product) {
                num_a = array[left];
                num_b = array[right];
                product = array[left] * array[right];
                valid = true;
                right--;
            } else {
                break;
            }
        }
        if (valid) {
            result.push_back(num_a);
            result.push_back(num_b);
        }
        return result;
    }
};
和快排思想类似,就是同时从前往后和从后往前遍历.注意上述代码有个风险是两个数的乘积会不会过大.
5-剑指offer: 和为S的两个数字的更多相关文章
- 剑指Offer 和为S的两个数字
		题目描述 输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的. 输出描述: 对应每个测试案例,输出两个数,小的先输出. 思路 ... 
- 剑指 Offer——和为 S 的两个数字
		1. 题目 2. 解答 由于数组是已经排好序的,我们可以定义两个指针,第一个指针指向第一个元素,第二个指针指向最后一个元素,然后求出这两个元素的和,与目标和进行比较.若小于目标和,第一个指针向前移动: ... 
- 剑指Offer——和为S的两个数字
		题目描述: 输入一个递增排序的数组和一个数字S,在数组中查找两个数,是的他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的. 输入描述: 对应每个测试案例,输出两个数,小的先输出. ... 
- 剑指offer 和为s的两个数字的调试
		这是整个调试, for (int i:s) cout<<i<<endl;这句话是c++11特性下的一种遍历方式 在编译的时候需要加-std=c++11,即g++ 41.cpp ... 
- 剑指offer——和为s的两个数字VS和为s的连续正数序列
		两种方法都类似于快排的变形. #include <iostream> #include <string> using namespace std; bool FindNumbe ... 
- 《剑指offer》旋转数组中的最小数字
		本题来自<剑指offer> 旋转数组中的最小数字 题目: 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. 输入一个非减排序的数组的一个旋转,输出旋转数组的最小元素. 例 ... 
- 剑指Offer - 九度1509 - 树中两个结点的最低公共祖先
		剑指Offer - 九度1509 - 树中两个结点的最低公共祖先2014-02-07 01:04 题目描述: 给定一棵树,同时给出树中的两个结点,求它们的最低公共祖先. 输入: 输入可能包含多个测试样 ... 
- 剑指Offer - 九度1519 - 合并两个排序的链表
		剑指Offer - 九度1519 - 合并两个排序的链表2013-11-30 22:04 题目描述: 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则.(hi ... 
- 剑指Offer - 九度1512 - 用两个栈实现队列
		剑指Offer - 九度1512 - 用两个栈实现队列2013-11-29 21:23 题目描述: 用两个栈来实现一个队列,完成队列的Push和Pop操作.队列中的元素为int类型. 输入: 每个输入 ... 
- 剑指 Offer 62. 圆圈中最后剩下的数字 + 约瑟夫环问题
		剑指 Offer 62. 圆圈中最后剩下的数字 Offer_62 题目描述 方法一:使用链表模拟 这种方法是暴力方法,时间复杂度为O(nm),在本题中数据量过大会超时. 方法二:递归方法 packag ... 
随机推荐
- HTML与CSS学习笔记(7)
			1.响应式布局 利用媒体查询,即media queries,可以针对不同的媒体类型定义不同的样式,从而实现响应式布局. 常见选项: 媒体类型 and.not min-width.max-width: ... 
- C++ trais技术 模板特化的应用
			// traits 的应用 /////////////////////////////////////////// // traits template <typename T> clas ... 
- MongoDB概念认识(四)
			1. database 一个mongodb中可以建立多个数据库. MongoDB的默认数据库为"db",该数据库存储在data目录中. MongoDB的单个实例可以容纳多个独立的数 ... 
- ASP.NET开发实战——(六)ASP.NET MVC & 分层 代码篇
			上一篇文章对如何规范使用ASP.NET进行了介绍,本章内容将根据上一篇得出的结论来修改博客应用的代码. 代码分层 综合考虑将博客应用代码分为以下几个层次: ○ 模型:代表应用程序中的数据模型,与数据库 ... 
- pycharm配置docker
- Educational Codeforces Round 69 (Rated for Div. 2) C. Array Splitting 水题
			C. Array Splitting You are given a sorted array 
- [LeetCode] 238. Product of Array Except Self 除本身之外的数组之积
			Given an array nums of n integers where n > 1, return an array output such that output[i] is equ ... 
- 纯CSS打造BiliBili样式博客主题
			前言 一直以来,我都在思考如何减少不必要的JS代码,仅通过CSS来实现博客园主题美化.CSS有很多魔法代码,例如:before,iconfont,order,等等,利用好这些技巧,也能实现很好美化效果 ... 
- navicat远程连接mysql的方法
			navicat远程连接mysql的方法1 先在打开phpmyadmin 添加用户 用户名和密码自己设置 设置如下 2 关闭防火墙service iptables status可以查看到iptables ... 
- SpringDataSolr入门
			1 Spring Data Solr简介 虽然支持任何编程语言的能力具有很大的市场价值,你可能感兴趣的问题是:我如何将Solr的应用集成到Spring中?可以,Spring Data Solr就是为了 ... 
