力扣第一题

给定一个整数数组 nums 和一个整数目标值 target,
请你在该数组中找出 和为目标值 target  的那 两个 整数,
并返回它们的数组下标。你可以假设每种输入只会对应一个答案。
但是,数组中同一个元素在答案里不能重复出现。


有两种实现方式

	public static void main(String[] args) {
		
		int[] nums = {7,2,11,15};
		int target = 13;
		System.out.println(Arrays.toString(twoSum2(nums,target)));
	}
	
	//一种方式,O(n^2)
	public static int[] twoSum1(int[] nums, int target) {
		for(int i = 0; i < nums.length; i ++){
			for(int j = i + 1; j < nums.length; j ++){
				if(nums[i] + nums[j] == target){
					return new int[]{i,j};
				}
			}
		}
		return null;
    }
	
	//7,2,11,15  13  O(n)          
	public static int[] twoSum2(int[] nums, int target) {
		//map的key是数组里的元素,map的value是下标
		Map<Integer,Integer> map = new HashMap<>();
		for(int i = 0; i < nums.length; i ++){
			if(map.containsKey(target - nums[i])){
				return new int[]{map.get(target - nums[i]),i};
			}
			map.put(nums[i], i);
		}
		return null;
    }
posted @ 2021-12-21 14:56  卡卡罗特琪琪  阅读(48)  评论(0编辑  收藏  举报