|
|
|
---
|
|
|
|
数组相关
|
|
|
|
---
|
|
|
|
|
|
|
|
[04. 二维数组中的查找](https://leetcode-cn.com/problems/er-wei-shu-zu-zhong-de-cha-zhao-lcof/)
|
|
|
|
|
|
|
|
```java
|
|
|
|
class Solution {
|
|
|
|
|
|
|
|
public boolean findNumberIn2DArray(int[][] matrix, int target) {
|
|
|
|
if (matrix == null || matrix.length == 0) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
int m = matrix.length, n = matrix[0].length;
|
|
|
|
int row = 0, col = n - 1;
|
|
|
|
while (row < m && col >= 0) {
|
|
|
|
if (matrix[row][col] > target) {
|
|
|
|
col--;
|
|
|
|
} else if (matrix[row][col] < target) {
|
|
|
|
row++;
|
|
|
|
} else {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
[11. 旋转数组的最小数字](https://leetcode-cn.com/problems/xuan-zhuan-shu-zu-de-zui-xiao-shu-zi-lcof/)
|
|
|
|
|
|
|
|
```java
|
|
|
|
class Solution {
|
|
|
|
|
|
|
|
public int minArray(int[] numbers) {
|
|
|
|
int i = 0, j = numbers.length - 1;
|
|
|
|
while (i < j) {
|
|
|
|
int m = (i + j) / 2;
|
|
|
|
if (numbers[m] > numbers[j]) {
|
|
|
|
i = m + 1;
|
|
|
|
} else if (numbers[m] < numbers[j]) {
|
|
|
|
j = m;
|
|
|
|
} else {
|
|
|
|
j--;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return numbers[i];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
[21. 调整数组顺序使奇数位于偶数前面](https://leetcode-cn.com/problems/diao-zheng-shu-zu-shun-xu-shi-qi-shu-wei-yu-ou-shu-qian-mian-lcof/)
|
|
|
|
|
|
|
|
```java
|
|
|
|
class Solution {
|
|
|
|
|
|
|
|
public int[] exchange(int[] nums) {
|
|
|
|
int i = 0, j = nums.length - 1;
|
|
|
|
while (i < j) {
|
|
|
|
if (nums[i] % 2 == 1 && nums[j] % 2 == 0) {
|
|
|
|
i++;
|
|
|
|
j--;
|
|
|
|
} else if (nums[i] % 2 == 1 && nums[j] % 2 == 1) {
|
|
|
|
i++;
|
|
|
|
} else if (nums[i] % 2 == 0 && nums[j] % 2 == 1) {
|
|
|
|
int temp = nums[i];
|
|
|
|
nums[i++] = nums[j];
|
|
|
|
nums[j--] = temp;
|
|
|
|
} else {
|
|
|
|
j--;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nums;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
```java
|
|
|
|
class Solution {
|
|
|
|
|
|
|
|
public int[] exchange(int[] nums) {
|
|
|
|
int i = 0, j = nums.length - 1, temp;
|
|
|
|
while (i < j) {
|
|
|
|
while (i < j && (nums[i] & 1) == 1) {
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
while (i < j && (nums[j] & 1) == 0) {
|
|
|
|
j--;
|
|
|
|
}
|
|
|
|
temp = nums[i];
|
|
|
|
nums[i] = nums[j];
|
|
|
|
nums[j] = temp;
|
|
|
|
}
|
|
|
|
return nums;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
[39. 数组中出现次数超过一半的数字](https://leetcode-cn.com/problems/shu-zu-zhong-chu-xian-ci-shu-chao-guo-yi-ban-de-shu-zi-lcof/)
|
|
|
|
|
|
|
|
```java
|
|
|
|
class Solution {
|
|
|
|
|
|
|
|
public int majorityElement(int[] nums) {
|
|
|
|
Arrays.sort(nums);
|
|
|
|
return nums[nums.length / 2];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
```java
|
|
|
|
class Solution {
|
|
|
|
|
|
|
|
public int majorityElement(int[] nums) {
|
|
|
|
int count = 0, result = 0;
|
|
|
|
for (int num : nums) {
|
|
|
|
if (count == 0) {
|
|
|
|
result = num;
|
|
|
|
}
|
|
|
|
count += (result == num) ? 1 : -1;
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
[42. 连续子数组的最大和](https://leetcode-cn.com/problems/lian-xu-zi-shu-zu-de-zui-da-he-lcof/)
|
|
|
|
|
|
|
|
```java
|
|
|
|
class Solution {
|
|
|
|
|
|
|
|
public int maxSubArray(int[] nums) {
|
|
|
|
int max = Integer.MIN_VALUE;
|
|
|
|
int sum = 0;
|
|
|
|
for (int num : nums) {
|
|
|
|
if (sum <= 0) {
|
|
|
|
sum = num;
|
|
|
|
} else {
|
|
|
|
sum += num;
|
|
|
|
}
|
|
|
|
max = Math.max(max, sum);
|
|
|
|
}
|
|
|
|
return max;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
```java
|
|
|
|
class Solution {
|
|
|
|
|
|
|
|
public int maxSubArray(int[] nums) {
|
|
|
|
int res = nums[0];
|
|
|
|
for (int i = 1; i < nums.length; i++) {
|
|
|
|
nums[i] += Math.max(nums[i - 1], 0);
|
|
|
|
res = Math.max(res, nums[i]);
|
|
|
|
}
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
[45. 把数组排成最小的数](https://leetcode-cn.com/problems/ba-shu-zu-pai-cheng-zui-xiao-de-shu-lcof/)
|
|
|
|
|
|
|
|
```java
|
|
|
|
class Solution {
|
|
|
|
public String minNumber(int[] nums) {
|
|
|
|
String[] strings = getStringArray(nums);
|
|
|
|
Arrays.sort(strings, new Cop());
|
|
|
|
|
|
|
|
StringBuilder result = new StringBuilder();
|
|
|
|
for (String s : strings) {
|
|
|
|
result.append(s);
|
|
|
|
}
|
|
|
|
return result.toString();
|
|
|
|
}
|
|
|
|
|
|
|
|
private String[] getStringArray(int[] nums) {
|
|
|
|
String[] strings = new String[nums.length];
|
|
|
|
for (int i = 0; i < nums.length; i++) {
|
|
|
|
strings[i] = String.valueOf(nums[i]);
|
|
|
|
}
|
|
|
|
return strings;
|
|
|
|
}
|
|
|
|
|
|
|
|
class Cop implements Comparator<String> {
|
|
|
|
@Override
|
|
|
|
public int compare(String o1, String o2) {
|
|
|
|
String s1 = o1 + o2;
|
|
|
|
String s2 = o2 + o1;
|
|
|
|
return s1.compareTo(s2);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
```java
|
|
|
|
class Solution {
|
|
|
|
public String minNumber(int[] nums) {
|
|
|
|
String[] strings = new String[nums.length];
|
|
|
|
for (int i = 0; i < nums.length; i++) {
|
|
|
|
strings[i] = String.valueOf(nums[i]);
|
|
|
|
}
|
|
|
|
Arrays.sort(strings, (o1, o2) -> (o1 + o2).compareTo(o2 + o1));
|
|
|
|
|
|
|
|
StringBuilder result = new StringBuilder();
|
|
|
|
for (String s : strings) {
|
|
|
|
result.append(s);
|
|
|
|
}
|
|
|
|
return result.toString();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|