目录
2. 最大数 🌟🌟
3. 颜色分类 🌟🌟
1. Excel表列序号
给你一个字符串 columnTitle
,表示 Excel 表格中的列名称。返回该列名称对应的列序号。
例如,
A -> 1 B -> 2 C -> 3 ... Z -> 26 AA -> 27 AB -> 28 ...
示例 1:
输入: columnTitle = "A" 输出: 1
示例 2:
输入: columnTitle = "AB" 输出: 28
示例 3:
输入: columnTitle = "ZY" 输出: 701
示例 4:
输入: columnTitle = "FXSHRXW" 输出: 2147483647
提示:
1 <= columnTitle.length <= 7
columnTitle
仅由大写英文组成columnTitle
在范围["A", "FXSHRXW"]
内
出处:
https://edu.csdn.net/practice/24183753
代码: 原题选项
class Solution {
public int titleToNumber(String s) {
char[] charArray = s.toCharArray();
int res = 0;
for (int i = 0; i < charArray.length; i++) {
res = res * 26 + (charArray[i] - 'A' + 1);
}
return res;
}
}
或者: String.charAt(index)
class Solution {
public int titleToNumber(String columnTitle) {
int res = 0;
for (int i = 0; i < columnTitle.length(); i++) {
char c = columnTitle.charAt(i);
res = res * 26 + (c - 'A' + 1);
}
return res;
}
}
2. 最大数
给定一组非负整数 nums
,重新排列每个数的顺序(每个数不可拆分)使之组成一个最大的整数。
注意:输出结果可能非常大,所以你需要返回一个字符串而不是整数。
示例 1:
输入:nums = [10,2] 输出:"210"
示例 2:
输入:nums = [3,30,34,5,9] 输出:"9534330"
示例 3:
输入:nums = [1] 输出:"1"
示例 4:
输入:nums = [10] 输出:"10"
提示:
1 <= nums.length <= 100
0 <= nums[i] <= 10^9
出处:
https://edu.csdn.net/practice/24183754
代码:
class Solution {
public String largestNumber(int[] nums) {
String[] str = new String[nums.length];
for (int i = 0; i < nums.length; i++)
str[i] = String.valueOf(nums[i]);
Arrays.parallelSort(str);
for (int i = 1; i < str.length; i++)
for (int j = 0; j < i; j++) {
if (str[i].length() > str[j].length() && str[i].substring(0, str[j].length()).equals(str[j])) {
StringBuilder str1 = new StringBuilder();
StringBuilder str2 = new StringBuilder();
str1.append(str[i] + str[j]);
str2.append(str[j] + str[i]);
if (str2.toString().compareTo(str1.toString()) > 0) {
String tmp = str[i];
str[i] = str[j];
str[j] = tmp;
}
}
}
StringBuilder ans = new StringBuilder();
for (int i = str.length - 1; i >= 0; i--)
ans.append(str[i]);
return ans.charAt(0) == '0' ? "0" : ans.toString();
}
}
自定义排序:
class Solution {
public String largestNumber(int[] nums) {
String[] strNums = new String[nums.length];
for (int i = 0; i < nums.length; i++) {
strNums[i] = String.valueOf(nums[i]);
}
Arrays.sort(strNums, (s1, s2) -> (s2 + s1).compareTo(s1 + s2));
if (strNums[0].equals("0")) {
return "0";
}
StringBuilder res = new StringBuilder();
for (String str : strNums) {
res.append(str);
}
return res.toString();
}
}
快速排序:
class Solution {
public String largestNumber(int[] nums) {
quickSort(nums, 0, nums.length - 1);
if (nums[0] == 0) {
return "0";
}
StringBuilder res = new StringBuilder();
for (int num : nums) {
res.append(num);
}
return res.toString();
}
private void quickSort(int[] nums, int left, int right) {
if (left >= right) {
return;
}
int i = left, j = right;
int pivot = nums[left];
while (i < j) {
while (i < j && compare(nums[j], pivot) <= 0) {
j--;
}
nums[i] = nums[j];
while (i < j && compare(nums[i], pivot) >= 0) {
i++;
}
nums[j] = nums[i];
}
nums[i] = pivot;
quickSort(nums, left, i - 1);
quickSort(nums, i + 1, right);
}
private int compare(int num1, int num2) {
String s1 = String.valueOf(num1);
String s2 = String.valueOf(num2);
return (s2 + s1).compareTo(s1 + s2);
}
}
3. 颜色分类
给定一个包含红色、白色和蓝色,一共 n
个元素的数组,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。
此题中,我们使用整数 0
、 1
和 2
分别表示红色、白色和蓝色。
示例 1:
输入:nums = [2,0,2,1,1,0] 输出:[0,0,1,1,2,2]
示例 2:
输入:nums = [2,0,1] 输出:[0,1,2]
示例 3:
输入:nums = [0] 输出:[0]
示例 4:
输入:nums = [1] 输出:[1]
提示:
n == nums.length
1 <= n <= 300
nums[i]
为0
、1
或2
进阶:
- 你可以不使用代码库中的排序函数来解决这道题吗?
- 你能想出一个仅使用常数空间的一趟扫描算法吗?
出处:
https://edu.csdn.net/practice/24183755
代码:
class Solution {
public void sortColors(int[] nums) {
int low = 0, high = nums.length - 1;
int i = 0;
while (i <= high) {
if (nums[i] == 0) {
int tmp = nums[i];
nums[i] = nums[low];
nums[low] = tmp;
++low;
++i;
} else if (nums[i] == 1) {
++i;
} else if (i <= high && nums[i] == 2) {
int tmp = nums[i];
nums[i] = nums[high];
nums[high] = tmp;
--high;
}
}
}
}
计数排序:
class Solution {
public void sortColors(int[] nums) {
int[] counts = new int[3]; // 统计 0, 1, 2 出现的次数
for (int i = 0; i < nums.length; i++) {
counts[nums[i]]++;
}
int index = 0;
for (int i = 0; i < counts[0]; i++) {
nums[index++] = 0;
}
for (int i = 0; i < counts[1]; i++) {
nums[index++] = 1;
}
for (int i = 0; i < counts[2]; i++) {
nums[index++] = 2;
}
}
}
快速排序:
class Solution {
public void sortColors(int[] nums) {
int left = 0, right = nums.length - 1;
int i = 0;
while (i <= right) {
if (nums[i] == 0) {
swap(nums, i, left);
left++;
i++;
} else if (nums[i] == 2) {
swap(nums, i, right);
right--;
} else {
i++;
}
}
}
private void swap(int[] nums, int i, int j) {
int temp = nums[i];
nums[i] = nums[j];
nums[j] = temp;
}
}
🌟 每日一练刷题专栏 🌟
✨ 持续,努力奋斗做强刷题搬运工!
👍 点赞,你的认可是我坚持的动力!
🌟 收藏,你的青睐是我努力的方向!
✎ 评论,你的意见是我进步的财富!
☸ 主页:https://hannyang.blog.csdn.net/