zoukankan      html  css  js  c++  java
  • 剑指offer 42.知识迁移能力 和为S的两个数字

    题目描述

    输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。

    输出描述

    对应每个测试案例,输出两个数,小的先输出。
     

    解题思路

    先用两个for循环,找出数组中和为sum的两个数字对,并把他们一个作为key,一个作为value添加进一个Map<Integer,Integer>中,然后再遍历Map,得到乘积最小的数字对,添加进ArrayList中。

    代码如下

    public ArrayList<Integer> FindNumbersWithSum(int [] array,int sum) {
        Map<Integer, Integer> map=new HashMap<Integer, Integer>(2);
        ArrayList<Integer> list=new ArrayList<Integer>();
        for (int i = 0; i < array.length; i++) {
            int tmp=array[i];
            for (int j = i+1; j < array.length; j++) {
                
                if (array[i]+array[j]==sum) {
                    map.put(array[i], array[j]);
                }else if (array[i]+array[j]>sum) {
                    break;
                }
            }    
        }
        int min=Integer.MAX_VALUE;
        for (Entry<Integer, Integer> m:map.entrySet()) {
            if (m.getKey()*m.getValue()<min) {
                min=m.getKey()*m.getValue();
                list.add(0, m.getKey());
                list.add(1, m.getValue());
            };
        }
    
        return list;
            
        }
  • 相关阅读:
    MogileFS的实现和bug解决
    MogileFS介绍
    SAMBA
    NFS
    测试DNS服务的命令
    DNS中的AC、rndc、智能DNS解析和基础排错
    DNS的主从、子域授权和转发服务器
    DNS域名记录
    DNS
    JavaScript设计模式与开发实践随笔(二)
  • 原文地址:https://www.cnblogs.com/Transkai/p/11375331.html
Copyright © 2011-2022 走看看