LeetCode(Hot100)——1:两数之和

方法1:暴力求解

  • 利用两次for循环来处理, 外循环确定一个数字, 利用内循环不断求和来判断是否两数之和为target,来进行求解。
java 复制代码
public class LeetCode1 {
    @Test
    //测试方法
    public void test() {
        int [] nums={2,7,11,15};
        int target=9;
        //调用方法
        System.out.println(Arrays.toString(twoSum(nums,target)));
    }


    //暴力求解
    public int[] twoSum(int[] nums, int target) {
        for(int i=0;i<nums.length;i++){
            for(int j=i+1;j<nums.length;i++){
                if(nums[i]+nums[j]==target)
                {
                    //if(i!=j&&nums[i]+nums[j]==target)
                    //返回一个数组,new一个数组。
                    return new int[]{i,j};
                }
            }
        }
        //定义返回值应该是int类型的数组,所以更合理的解释是返回return new int[0](本身的含义是长度为0的空数组)
        return new int[0];
        
        //假设一个方法返回一个数组,如果它返回null,则调用方法必须先判断是否返回null,才能对返回数组进一步处理,而如果返回空数组,则无须null引用检查
        //return null;
    }
}

暴力求解的时间复杂度是O(n2)

方法2:哈希映射

  • 哈希的时间复杂度为O(1),利用哈希容器map降低时间复杂度
  • 遍历数组 nums,i 为当前下标,每个值都判断map中是否存在 target-nums[i] 的 key 值
  • 如果存在则找到了两个值,如果不存在则将当前的 (nums[i],i) 存入 map中,继续遍历直到找到为止
  • 如果最终都没有结果则抛出异常
java 复制代码
 // 哈希表存储检查过的数字
public int[] twoSum(int[] nums, int target) {
    // 创建一个哈希表用于存储检查过的数字
    Map<Integer, Integer> map = new HashMap<>();
    
    // 遍历数组
    for(int i = 0; i < nums.length; i++) {
        // 计算目标值与当前数字的差值
        int complement = target - nums[i];
        
        // 检查哈希表中是否包含差值
        if(map.containsKey(complement)) {
            // 如果存在差值,则返回差值的索引和当前数字的索引
            // 如果HashMap中包含target-nums[i],则返回HashMap中target-nums[i]对应的值和i
            return new int[] {map.get(complement), i};
        }
        
         // 将nums[i]和i放入HashMap中
        map.put(nums[i], i);
    }
    
      // 如果没有找到,则返回一个长度为0的数组
    return new int[0];;
}
相关推荐
uhakadotcom29 分钟前
Apache Airflow入门指南:数据管道的强大工具
算法·面试·github
跳跳糖炒酸奶1 小时前
第四章、Isaacsim在GUI中构建机器人(2):组装一个简单的机器人
人工智能·python·算法·ubuntu·机器人
绵绵细雨中的乡音1 小时前
动态规划-第六篇
算法·动态规划
程序员黄同学1 小时前
动态规划,如何应用动态规划解决实际问题?
算法·动态规划
march_birds2 小时前
FreeRTOS 与 RT-Thread 事件组对比分析
c语言·单片机·算法·系统架构
斯汤雷2 小时前
Matlab绘图案例,设置图片大小,坐标轴比例为黄金比
数据库·人工智能·算法·matlab·信息可视化
云 无 心 以 出 岫3 小时前
贪心算法QwQ
数据结构·c++·算法·贪心算法
渗透测试老鸟-九青3 小时前
面试经验分享 | 成都渗透测试工程师二面面经分享
服务器·经验分享·安全·web安全·面试·职场和发展·区块链
俏布斯3 小时前
算法日常记录
java·算法·leetcode
独好紫罗兰3 小时前
洛谷题单3-P5719 【深基4.例3】分类平均-python-流程图重构
开发语言·python·算法