问题说明: 1.和为s的两个数问题是从一个排序的数组中找出和为s的两个数; 2.原题是找出一个即可,现在全部找出; 3.和为s的连续正数数列是给定一个数找出所有连续正数数列的和为s,例如s为9,(2,3,4)就是其中一组。 (一)和为s的两个数问题 public static int findNumbersWithSum(int[] sorted, int fromIndex, in
思路:首先就是O(n)时间复杂度,O(n)空间复杂度的,其实很简单,我们只需要定义一个哈希表,遍历一遍数组的时候计数数组中的元素就行;之后再次遍历一遍,只不过这回是从1开始比照哈希表里存不存在这个正整数,从而获得答案。 class Solution {public int firstMissingPositive(int[] nums) {Map<Integer,Integer>map=new
问题:输入一个整数n,求从1到n这n个整数的十进制中1出现的次数。 详细实现代码如下: // ====================方法一:穷举====================int NumberOf1(unsigned int n);int NumberOf1Between1AndN_Solution1(unsigned int n){int number =
解题思路: 原地哈希 就相当于,让每个数字n都回到下标为n-1的家里。 而那些没有回到家里的就成了孤魂野鬼流浪在外,他们要么是根本就没有自己的家(数字小于等于0或者大于nums.size()),要么是自己的家被别人占领了(出现了重复)。 class Solution {public int firstMissingPositive(int[] nums) {int len = nu