【leetcode】第三章 哈希表part02

news/2024/11/22 12:52:16/

454.四数相加II

public int fourSumCount(int[] nums1, int[] nums2, int[] nums3, int[] nums4) {HashMap<Integer,Integer> map = new HashMap<>();// 统计频率for (int i = 0; i < nums1.length; i++) {for (int j = 0; j < nums2.length; j++) {int num = nums1[i] + nums2[j];map.put(num,map.getOrDefault(num,0)+1);}}int cnt = 0;for (int i = 0; i < nums3.length; i++) {for (int j = 0; j < nums4.length; j++) {int restNum = nums3[i] + nums4[j];if (map.containsKey(-restNum)) {cnt += map.get(-restNum);}}}return cnt;
}

383. 赎金信

  • 使用map方法
public boolean canConstruct(String ransomNote, String magazine) {// ransomNote是magazine的子串// aa aabcdeaHashMap<Character,Integer> map = new HashMap<>();for (char c : ransomNote.toCharArray()) {map.put(c,map.getOrDefault(c,0)+1);}for (int i = 0; i < magazine.length(); i++) {char ch = magazine.charAt(i);if (map.containsKey(ch)) {map.put(ch,map.get(ch)-1);}}// 判断for (Integer cnt : map.values()) {if (cnt > 0) return false;}return true;}
  • 使用数组方法
public boolean canConstruct(String ransomNote, String magazine) {// ransomNote是magazine的子串// aa abint[] hash = new int[26];for (int i = 0; i < magazine.length(); i++) {char ch = magazine.charAt(i);hash[ch-'a']++;}for (int i = 0; i < ransomNote.length(); i++) {char c  = ransomNote.charAt(i);hash[c-'a']--;if (hash[c-'a'] < 0) {return false;}}return true;}

15 三数之和

public List<List<Integer>> threeSum(int[] nums) {Arrays.sort(nums);List<List<Integer>> res = new ArrayList<>();for (int i = 0; i < nums.length-2; i++) {if (nums[i] > 0) break;if (i != 0 && nums[i] == nums[i-1]) {continue;}int left = i + 1;int right = nums.length-1;while (left < right) {int target = nums[i] + nums[left] + nums[right];if (target == 0) {res.add(Arrays.asList(nums[i],nums[left],nums[right]));while (left < right && nums[left] == nums[left+1]) left++;while (left < right && nums[right] == nums[right-1]) right--;left++;right--;}else if (target < 0) {left++;}else {right--;}}}return res;
}

18. 四数之和

public List<List<Integer>> fourSum(int[] nums, int target) {// 输入:nums = [1,0,-1,0,-2,2], target = 0//输出:[[-2,-1,1,2],[-2,0,0,2],[-1,0,0,1]]List<List<Integer>> res = new ArrayList<>();Arrays.sort(nums);for (int i = 0; i < nums.length-3; i++) {// // 剪枝if (nums[i] > target && target >= 0) return res;if (i > 0 && nums[i] == nums[i-1]) continue;for (int j = i+1; j < nums.length-2; j++) {// 剪枝if (j > i+1 && nums[j] == nums[j-1]) continue;int left = j+1;int right = nums.length-1;while (left < right) {long num = (long)nums[i] + nums[j] + nums[left] + nums[right];if (num == target) {res.add(Arrays.asList(nums[i],nums[j],nums[left],nums[right]));while (left < right && nums[left] == nums[left+1]) left++;while (left < right && nums[right] == nums[right-1]) right--;left++;right--;}else if (num < target) {left++;}else {right--;}}}}return res;
}

http://www.ppmy.cn/news/1035616.html

相关文章

概念解析 | 长尾分布:从无处不在的‘少数派’中挖掘价值

注1:本文系“概念解析”系列之一,致力于简洁清晰地解释、辨析复杂而专业的概念。本次辨析的概念是:长尾分布(Long-Tail Distribution)。 揭秘长尾分布:从无处不在的‘少数派’中挖掘价值 What is a Long Tail Distribution? (Definition & Example) - Statology 一、背…

短除法(c++)

题号标题1389数据分析1750有0的数1962数值计算1121“倒”数1469数的统计1511数字之和为13的整数1149回文数个数1846阿尔法乘积短除法 目录 1389 - 数据分析 题目描述某军事单位为了保证信息的安全性&#xff0c;决定采用特殊的加密方法来传递信息&#xff0c;该方法的操作方…

系统架构设计师---考试通关练习题

第一章 系统架构设计师概述 1 .以下()不是现代信息系统的架构的三个要素。 A.构件 B.模式 C.规划 D.属性 解析:现代信息系统的架构有三个要素,即构件、模式和规划。 答案:D 2. 软件系统架构是关于软件系统的结构、行为和()的高级抽象。 A.构件 B.模式 C…

华为OD机试真题【组合出合法最小数】

1、题目描述 【组合出合法最小数】 给一个数组&#xff0c;数组里面都是代表非负整数的字符串&#xff0c;将数组里所有的数值排列组合拼接起来组成一个数字&#xff0c;输出拼接成的最小的数字。 【输入描述】 一个数组&#xff0c;数组不为空&#xff0c;数组里面都是代表非…

opencv进阶02-在图像上绘制多种几何图形

OpenCV 提供了方便的绘图功能&#xff0c;使用其中的绘图函数可以绘制直线、矩形、圆、椭圆等多种几何图形&#xff0c;还能在图像中的指定位置添加文字说明。 OpenCV 提供了绘制直线的函数 cv2.line()、绘制矩形的函数 cv2.rectangle()、绘制圆的函数cv2.circle()、绘制椭圆的…

Java异步方法CompletableFuture类的使用

Java中常用的异步方法 1、使用线程&#xff1a;你可以创建一个新的线程来执行异步操作。这可以通过直接创建Thread对象并启动它&#xff0c;或者使用线程池来管理线程的生命周期。 new Thread(() -> {// 异步操作代码 }).start(); 2、使用线程池Executor框架&#xff1a;E…

【C语言实战项目】通讯录

一.了解项目功能 在本次实战项目中我们的目标是实现一个通讯录: 该通讯录可以用来存储1000个人的信息 每个人的信息包括&#xff1a;姓名、年龄、性别、住址、电话 通讯录提供功能有&#xff1a; 添加联系人信息删除指定联系人信息查找指定联系人信息修改指定联系人信息显示所有…

SSM——用户、角色、权限操作

1. 数据库与表结构 1.1 用户表 1.1.1 用户表信息描述 users 1.1.2 sql语句 CREATE TABLE users( id varchar2(32) default SYS_GUID() PRIMARY KEY, email VARCHAR2(50) UNIQUE NOT NULL, username VARCHAR2(50), PASSWORD VARCHAR2(50), phoneNum VARCHAR2(20), STATUS INT…