算法面试题

1.经典两数之和

给定一个整数数组nums,和一个目标值target,找出数组中两个数,使他们的和等于target,输出他们的下标。

java 复制代码
import java.util.HashMap;
public class Test{
	public static void main(String[] args){
		Test t = new Test();
		t.twoSum2();
	}
	
	void twoSum1(){
		int[] arr = {1,2,3,4,5,6,7,8,9};
		
		int target = 6;
		
		int index1=0;
		int index2=0;
		System.out.println("target="+target);
		for(int i=0;i<arr.length;i++){
			for(int j=i+1;j<arr.length;j++){
				if(arr[i]+arr[j]==target){
					index1=i;
					index2=j;
					System.out.printf("\n%d, %d", i, j);
					//System.out.println("index1="+index1+",value="+arr[index1]+", index2="+index2+",value="+arr[index2]);
				}
			}
		}
	}
	//1.用HasmMap存储值->下标
	//2.遍历数组,对每个数:
	//计算需要的补数
	//如果补数已经在map里面,直接输出map.get(complement), i
	//把当前num和下标i存入map
	void twoSum2(){
		int[] arr = {1,2,3,4,5,6,7,8,9};
		
		int target = 6;
		
		HashMap<Integer, Integer> map = new HashMap<>();
		
		for(int i=0;i<arr.length;i++){
			int num = target - arr[i];
			if(map.containsKey(num)){
				System.out.printf("\n%d, %d", i, map.get(num));
				//System.out.printf("\narr[%d]=%d, arr[%d]=%d",i,arr[i], map.get(num), num);
			}
			map.put(arr[i],i);
		}
	}
}
  • 方法1双重循环时间复杂度O(n^2)
  • 方法2哈希表解法,用空间换时间,只需要一重循环遍历,时间复杂度O(n),空间复杂度O(n)
相关推荐
梦梦代码精39 分钟前
BuildingAI 上部署自定义工作流智能体:5 个实用技巧
大数据·人工智能·算法·开源软件
Mr_pyx1 小时前
Spring AI 入门教程:Java开发者的AI应用捷径
java·人工智能·spring
Zephyr_01 小时前
Leedcode算法题
java·算法
流年如夢2 小时前
栈和列队(LeetCode)
数据结构·算法·leetcode·链表·职场和发展
苍煜2 小时前
Java开发IO零基础吃透:BIO、NIO、同步异步、阻塞非阻塞
java·python·nio
折哥的程序人生 · 物流技术专研2 小时前
Java面试85题图解版(一):基础核心篇
java·开发语言·后端·面试
AllData公司负责人3 小时前
通过Postgresql同步到Doris,全视角演示AllData数据中台核心功能效果,涵盖:数据入湖仓,数据同步,数据处理,数据服务,BI可视化驾驶舱
java·大数据·数据库·数据仓库·人工智能·python·postgresql
Hello.Reader3 小时前
算法基础(十)——分治思想把大问题拆成小问题
java·开发语言·算法
一只大袋鼠3 小时前
JavaWeb四种文件上传方式(下篇)
java·开发语言·springmvc·javaweb