最小栈(栈设计)删除有序数组中的重复项(数组双指针)最大数(贪心字符串)
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了最小栈(栈设计)删除有序数组中的重复项(数组双指针)最大数(贪心字符串)相关的知识,希望对你有一定的参考价值。
最小栈(栈、设计)
设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈。
- push(x) —— 将元素 x 推入栈中。
- pop() —— 删除栈顶的元素。
- top() —— 获取栈顶元素。
- getMin() —— 检索栈中的最小元素。
示例:
输入: ["MinStack","push","push","push","getMin","pop","top","getMin"] [[],[-2],[0],[-3],[],[],[],[]]
输出: [null,null,null,null,-3,null,0,-2]
解释: MinStack minStack = new MinStack(); minStack.push(-2); minStack.push(0); minStack.push(-3); minStack.getMin(); --> 返回 -3. minStack.pop(); minStack.top(); --> 返回 0. minStack.getMin(); --> 返回 -2.
提示:
- pop、top 和 getMin 操作总是在 非空栈 上调用。
解答:
class MinStack
Stack<Integer> data_stack;
Stack<Integer> min_stack;
/** initialize your data structure here. */
public MinStack()
data_stack = new Stack<Integer>();
min_stack = new Stack<Integer>();
public void push(int x)
data_stack.push(x);
if (min_stack.isEmpty())
min_stack.push(x);
else
if (x > min_stack.peek())
x = min_stack.peek();
min_stack.push(x);
public void pop()
data_stack.pop();
min_stack.pop();
public int top()
return data_stack.peek();
public int getMin()
return min_stack.peek();
/**
* Your MinStack object will be instantiated and called as such:
* MinStack obj = new MinStack();
* obj.push(x);
* obj.pop();
* int param_3 = obj.top();
* int param_4 = obj.getMin();
*/
删除有序数组中的重复项(数组、双指针)
给你一个有序数组 nums ,请你原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。 不要使用额外的数组空间,你必须在 原地**修改输入数组 **并在使用 O(1) 额外空间的条件下完成。
说明: 为什么返回数值是整数,但输出的答案是数组呢? 请注意,输入数组是以**「引用」**方式传递的,这意味着在函数里修改输入数组对于调用者是可见的。 你可以想象内部操作如下:
// nums 是以“引用”方式传递的。也就是说,不对实参做任何拷贝 int len = removeDuplicates(nums);
// 在函数里修改输入数组对于调用者是可见的。 // 根据你的函数返回的长度, 它会打印出数组中 该长度范围内 的所有元素。 for (int i = 0; i < len; i++) print(nums[i]);
示例 1:
输入:nums = [1,1,2]
输出:2, nums = [1,2]
解释:函数应该返回新的长度 2 ,并且原数组 nums 的前两个元素被修改为 1, 2 。不需要考虑数组中超出新长度后面的元素。
示例 2:
输入:nums = [0,0,1,1,1,2,2,3,3,4]
输出:5, nums = [0,1,2,3,4]
解释:函数应该返回新的长度 5 , 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4 。不需要考虑数组中超出新长度后面的元素。
提示:
- 0 <= nums.length <= 3 * 104
- -104 <= nums[i] <= 104
- nums 已按升序排列
解答:
class Solution
public int removeDuplicates(int[] nums)
if (nums == null || nums.length == 0)
return 0;
int a = 0;
for (int b = 1; b < nums.length; b++)
if (nums[a] != nums[b])
a++;
nums[a] = nums[b];
return a + 1;
最大数(贪心、字符串)
给定一组非负整数 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] <= 109
解答:
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();
26. 删除有序数组中的重复项(先后指针)
1.Description
给你一个 升序排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。
由于在某些语言中不能改变数组的长度,所以必须将结果放在数组nums的第一部分。更规范地说,如果在删除重复项之后有 k 个元素,那么 nums 的前 k 个元素应该保存最终结果。
将最终结果插入 nums 的前 k 个位置后返回 k 。
不要使用额外的空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。
2.Example
示例 1:
输入:nums = [1,1,2]
输出:2, nums = [1,2,_]
解释:函数应该返回新的长度 2 ,并且原数组 nums 的前两个元素被修改为 1, 2 。不需要考虑数组中超出新长度后面的元素。
示例 2:输入:nums = [0,0,1,1,1,2,2,3,3,4]
输出:5, nums = [0,1,2,3,4]
解释:函数应该返回新的长度 5 , 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4 。不需要考虑数组中超出新长度后面的元素。
3.My Code
我的办法就是记录当前最终的下标index,然后不断寻找第一个不同的数填入nums[index]即可。
class Solution
public:
int removeDuplicates(vector<int>& nums)
int cnt = 0;
for(int i=0;i<nums.size();i++)
nums[cnt]=nums[i];
cnt++;
int j=i+1;
while(j<nums.size() && nums[j]==nums[i] )
j++;
if(j>=nums.size())
return cnt;
else
i=j-1;
return cnt;
;
4.Code(先后指针)
先后指针,不需要index计数,nums[fast]和nums[fast-1]比较,slow指向待填的位置
class Solution
public:
int removeDuplicates(vector<int>& nums)
int n = nums.size();
if(n == 0)
return 0;
//nums[0]默认已经填了
int slow = 1,fast =1;
while(fast < n)
if(nums[fast] != nums[fast-1])
nums[slow] = nums[fast];
slow++;
fast++;
return slow;
;
以上是关于最小栈(栈设计)删除有序数组中的重复项(数组双指针)最大数(贪心字符串)的主要内容,如果未能解决你的问题,请参考以下文章