[Java]1.两数之和 - LeetCode
1 题目
 
2 思路与代码
- 思路一:暴力法(两层For循环)
- 时间复杂度:O(n^2)
- 对于每个元素,我们试图通过遍历数组的其余部分来寻找它所对应的目标元素,这将耗费 O(n) 的时间。因此时间复杂度为 O(n^2)。
 
- 空间复杂度:O(1)
- 原理:遍历每个元素 xx,并查找是否存在一个值与 target - x相等的目标元素
 
- 时间复杂度:O(n^2)
/**
 * Note: The returned array must be malloced, assume caller calls free().
 */
int* twoSum(int* nums, int numsSize, int target){
    static int result[2]= {0};
    for(int i=0;i<numsSize;i=i++){
        for(int j=i+1;j<numsSize;j=j++){ //【trick】“int j=i+1;”而非“int j=0”
            if(nums[i]+nums[j]==target){
                result[0] = i;
                result[1] = j;
                return result;
            }
        }
    }
    return result;
}
- 思路二:两遍哈希表
- 时间复杂度:O(n)
- 把包含有 n 个元素的列表遍历两次。由于哈希表将查找时间缩短到 O(1) ,所以时间复杂度为O(n)
 
- 空间复杂度:O(n)
- 所需的额外空间取决于哈希表中存储的元素数量,该表中存储了 n 个元素
 
 
- 时间复杂度:O(n)
 
class Solution {
    /*
     思路:两遍哈希表
     推荐文献:
        https://baijiahao.baidu.com/s?id=1628609734622761569&wfr=spider&for=pc
    */
    public int[] twoSum(int[] nums, int target) {
        HashMap<Integer, Integer> map = new HashMap();
        for(int i=0;i<nums.length;i++){
            map.put(nums[i],i);
        }
        for(int j=0;j<nums.length;j++){
            int tmp = target - nums[j];
            if(map.containsKey(tmp) && map.get(tmp)!=j){
                return new int [] { j, map.get(tmp) };
            }
        }
        throw new IllegalArgumentException("No two sum solution!");
    }
}
- 思路三:一遍哈希表
- 时间复杂度:O(n)
- 只遍历了包含有n 个元素的列表一次。在表中进行的每次查找只花费 O(1) 的时间
 
- 空间复杂度:O(n)
- 所需的额外空间取决于哈希表中存储的元素数量,该表最多需要存储 n 个元素。
 
- 原理:通过思路二,可以推得:上述过程可以一次完成。在进行迭代并将元素插入到表中的同时,我们还会回过头来检查表中是否已经存在当前元素所对应的目标元素。如果它存在,那我们已经找到了对应解,并立即将其返回。
 
- 时间复杂度:O(n)
class Solution {//一次Hash查表
    public int[] twoSum(int[] nums, int target) {
        HashMap<Integer, Integer> map = new HashMap();
        for(int i=0;i<nums.length;i++){
            int tmp = target - nums[i];
            if(map.containsKey(tmp) && map.get(tmp)!=i){
                return new int [] { i, map.get(tmp) };
            } else {
                map.put(nums[i],i);
            }
        }
        // for(int j=0;j<nums.length;j++){
        //     int tmp = target - nums[j];
        //     if(map.containsKey(tmp) && map.get(tmp)!=j){
        //         return new int [] { j, map.get(tmp) };
        //     }
        // }
        throw new IllegalArgumentException("No two sum solution!");
    }
}
 
3 参考文献
4 博文遗留问题
- (数据结构/Java中)HashMap/哈希表 查询的原理与实现?
[Java]1.两数之和 - LeetCode的更多相关文章
- Java实现两数之和等于二十
		找出数组中两个数字之和为20的两个数 代码实现 public static void main(String[] args) { // TODO Auto-generated method stub ... 
- 1. 两数之和 LeetCode
		给定一个整数数组和一个目标值,找出数组中和为目标值的两个数. 你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用. 示例: 给定 nums = [, , , ], target = 因为 n ... 
- 两数之和 [ leetcode ]
		原题地址:https://leetcode-cn.com/articles/two-sum/ 给定一个整数数组和一个目标值,找出数组中和为目标值的两个数. 你可以假设每个输入只对应一种答案,且同样的元 ... 
- 两数之和LeetCode
		给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但是,你不能重复利用这个数组中同样的元 ... 
- LeetCode刷题 1. Two Sum 两数之和 详解 C++语言实现 java语言实现
		1. Two Sum 两数之和 Given an array of integers, return indices of the two numbers such that they add up ... 
- leetCode:twoSum 两数之和 【JAVA实现】
		LeetCode 两数之和 给定一个整数数组,返回两个数字的索引,使它们相加到特定目标. 您可以假设每个输入只有一个解决方案,并且您可能不会两次使用相同的元素. 更多文章查看个人博客 个人博客地址:t ... 
- Java实现 LeetCode 653 两数之和 IV - 输入 BST(递归,找差值)
		653. 两数之和 IV - 输入 BST 给定一个二叉搜索树和一个目标结果,如果 BST 中存在两个元素且它们的和等于给定的目标结果,则返回 true. 案例 1: 输入: 5 / \ 3 6 / ... 
- Java实现 LeetCode 1两数之和
		1. 两数之和 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但是,你不能重复利用这 ... 
- Java实现 LeetCode 167 两数之和 II - 输入有序数组
		167. 两数之和 II - 输入有序数组 给定一个已按照升序排列 的有序数组,找到两个数使得它们相加之和等于目标数. 函数应该返回这两个下标值 index1 和 index2,其中 index1 必 ... 
随机推荐
- iframe中的target属性
			在使用iframe的时候,我们有时候会遇到,外面的链接,去操作iframe中的页面 <!DOCTYPE html> <html> <head> <meta c ... 
- webpack中css文件的代码分割
			module.exports = { output: { filename: '[name].js', chunkFilename: '[name].chunk.js', path: path.res ... 
- net.exe和net1.exe的区别&联系.
			system32文件夹下有一个net.exe和net1.exe,一般做渗透的时候,很多情况下管理员只知道删除net.exe而遗漏net1.exe,导致我们能继续do evil..... 一直没弄明白它 ... 
- 基于RestOn智能睡眠监测器的睡眠监测系统
			一.项目地址为: https://github.com/linqian123... 二.项目功能概述: 该项目实现的是一个基于RestOn智能睡眠监测器的睡眠监测系统.RestOn智能睡眠检测器通过W ... 
- github下载慢的问题
			1. 修改HOSTS文件:在“C:\Windows\System32\drivers\etc” 下的HOSTS文件,添加以下地址: 151.101.44.249 github.global.ssl. ... 
- [Google Guava] 8-区间
			原文链接 译文链接 译文:沈义扬 范例 1 List scores; 2 Iterable belowMedian =Iterables.filter(scores,Range.lessThan(me ... 
- 18、属性赋值-@Value赋值
			18.属性赋值-@Value赋值 18.1 使用@Value赋值三种方式 基本数值 可以写SPEL 表达式,例如: #{} 可以写${} ,取出配置文件中的值(在运行环境变量里面的值) package ... 
- linux笔试题
			1. cron 后台常驻程序 (daemon) 用于: A. 负责文件在网络中的共享 B. 管理打印子系统 C. 跟踪管理系统信息和错误 D. 管理系统日常任务的调度 2. 在大多数Linux发行版本 ... 
- 002_89C52_Proteus_DAC0832_输出50HZ,正弦波,三角波,矩形波,锯齿波
			(一)非常感谢:89C51与ad0832 输出正弦波,三角波,矩形波,锯齿波 (二)在上面的情况下进行程序的修改,实现50HZ的输出 (三)电路图 (三)输出方波 (四)输出锯齿波 (五)输出三角波 ... 
- pyecharts  v1 版本 学习笔记 散点图
			散点图 基本案例 from example.commons import Faker from pyecharts import options as opts from pyecharts.char ... 
