This is the 8th day of my participation in the Novembermore Challenge.The final text challenge in 2021
Some of the problems in the LeetCode problem set may have been skipped directly, so clean up the previous brush with LeetCode
21. Merge two ordered lists
Merges two ordered lists into a new ordered list and returns. A new list is formed by concatenating all the nodes of a given two lists.
Example:
Input: 1->2->4, 1->3->4 Output: 1->1->2->3->4->4
Source: LeetCode link: leetcode-cn.com/problems/me… Copyright belongs to the Collar buckle network. Commercial reprint please contact official authorization, non-commercial reprint please indicate the source.
So you create a new linked list and you compare them if neither of them is empty, and you use the smaller one and if one of them is empty, you use the other one to connect to the current remaining verticesCopy the code
/** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode(int x) { val = x; }} * * /
class Solution {
public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
// Similar to merge sort in merge sort
ListNode dummyHead = new ListNode(0);
ListNode cur = dummyHead;
while(l1 ! =null&& l2 ! =null) {
if (l1.val < l2.val) {
cur.next = l1;
cur = cur.next;
l1 = l1.next;
} else{ cur.next = l2; cur = cur.next; l2 = l2.next; }}// If either one is empty, join the other list directly
if (l1 == null) {
cur.next = l2;
} else {
cur.next = l1;
}
returndummyHead.next; }}Copy the code
22. Parenthesis generation
Given that n represents the logarithm of generating parentheses, write a function that generates all possible and valid combinations of parentheses.
For example, given n = 3, the generated result is:
[” ((())) “, “() () ()”, “() () ()”, “() () ()”, “() () ()”]
Source: LeetCode link: leetcode-cn.com/problems/ge… Copyright belongs to the Collar buckle network. Commercial reprint please contact official authorization, non-commercial reprint please indicate the source.
N pairs of parentheses must match the number of open parentheses greater than or equal to the number of close parentheses otherwise it's not matching parenthesesCopy the code
class Solution {
public List<String> generateParenthesis(int n) {
List<String> res = new ArrayList<String>();
generate(res, "".0.0, n);
return res;
}
Count1 counts the number of "(", count2 counts the number of")
public void generate(List<String> res , String ans, int count1, int count2, int n){
if(count1 > n || count2 > n) return;
if(count1 == n && count2 == n) res.add(ans);
if(count1 >= count2){
String ans1 = new String(ans);
generate(res, ans+"(", count1+1, count2, n);
generate(res, ans1+")", count1, count2+1, n); }}}Copy the code
Merge K sorted linked lists
Merge k sorted lists and return the merged sorted lists. Analyze and describe the complexity of the algorithm.
Example:
Input: [1 – > 4 – > 5, 1 – > 3 – > 4, 2 – > 6] output: 1 – > 1 – > 2 – > 3 – > 4 – > 4 – > 5 – > 6
Source: LeetCode link: leetcode-cn.com/problems/me… Copyright belongs to the Collar buckle network. Commercial reprint please contact official authorization, non-commercial reprint please indicate the source.
PriorityQueue is a kind of queue in Java that sort automatically, rewrite compare, custom sort and put all the linked lists in there, it's going to sort automatically and then when it prints it's going to create a new node every time and print itCopy the code
/** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode(int x) { val = x; }} * * /
class Solution {
public ListNode mergeKLists(ListNode[] lists) {
if (lists.length == 0) {
return null;
}
ListNode dummyHead = new ListNode(0);
ListNode curr = dummyHead;
PriorityQueue<ListNode> pq = new PriorityQueue<>(new Comparator<ListNode>() {
@Override
public int compare(ListNode o1, ListNode o2) {
returno1.val - o2.val; }});for (ListNode list : lists) {
if (list == null) {
continue;
}
pq.add(list);
}
while(! pq.isEmpty()) { ListNode nextNode = pq.poll(); curr.next = nextNode; curr = curr.next;if(nextNode.next ! =null) { pq.add(nextNode.next); }}returndummyHead.next; }}Copy the code
PS: divide and conquer
/** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode(int x) { val = x; }} * * /
class Solution {
public ListNode mergeKLists(ListNode[] lists){
if(lists.length == 0)
return null;
if(lists.length == 1)
return lists[0];
if(lists.length == 2) {return mergeTwoLists(lists[0],lists[1]);
}
int mid = lists.length/2;
ListNode[] l1 = new ListNode[mid];
for(int i = 0; i < mid; i++){
l1[i] = lists[i];
}
ListNode[] l2 = new ListNode[lists.length-mid];
for(int i = mid,j=0; i < lists.length; i++,j++){
l2[j] = lists[i];
}
return mergeTwoLists(mergeKLists(l1),mergeKLists(l2));
}
public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
if (l1 == null) return l2;
if (l2 == null) return l1;
ListNode head = null;
if (l1.val <= l2.val){
head = l1;
head.next = mergeTwoLists(l1.next, l2);
} else {
head = l2;
head.next = mergeTwoLists(l1, l2.next);
}
returnhead; }}Copy the code
Swap nodes in a linked list in pairs
Given a linked list, swap adjacent nodes in pairs and return the swapped list.
You can’t just change the values inside a node, you need to actually swap nodes.
Example:
Given 1->2->3->4, you should return 2->1->4->3.
Source: LeetCode link: leetcode-cn.com/problems/sw… Copyright belongs to the Collar buckle network. Commercial reprint please contact official authorization, non-commercial reprint please indicate the source.
Loop through two lists, exchanging the values of the two lists over and overCopy the code
/** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode(int x) { val = x; }} * * /
class Solution {
public ListNode swapPairs(ListNode head) {
ListNode pNode = head;
while(pNode! =null&&pNode.next ! =null) {
int tmp = pNode.val;
pNode.val= pNode.next.val;
pNode.next.val = tmp;
pNode = pNode.next.next;
}
returnhead; }}Copy the code
25. Flip linked lists in groups of K
You are given a linked list, each k nodes in a group of flipped, please return to the flipped list.
K is a positive integer whose value is less than or equal to the length of the list.
If the total number of nodes is not an integer multiple of k, keep the last remaining nodes in the same order.
Example:
Given the linked list: 1->2->3->4->5
When k = 2, it should return: 2->1->4->3->5
When k = 3, it should return: 3->2->1->4->5
Description:
Your algorithm can only use extra space of constants. You can’t just change the values inside a node, you need to actually swap nodes.
Source: LeetCode link: leetcode-cn.com/problems/re… Copyright belongs to the Collar buckle network. Commercial reprint please contact official authorization, non-commercial reprint please indicate the source.
PS: This list you taste your taste ~~~
/** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode(int x) { val = x; }} * * /
class Solution {
public ListNode reverseKGroup(ListNode head, int k) {
ListNode prev = null;
ListNode cur = head;
ListNode next = null;
ListNode check = head;
int canProceed = 0;
int count = 0;
// Check whether the list length meets the rollover
while(canProceed < k && check ! =null) {
check = check.next;
canProceed++;
}
// If the condition is met, perform the reverse
if (canProceed == k) {
while(count < k && cur ! =null) {
next = cur.next;
cur.next = prev;
prev = cur;
cur = next;
count++;
}
if(next ! =null) {
// head is the last node of the list flipped
head.next = reverseKGroup(next, k);
}
// prev is the head of the flipped list
return prev;
} else {
// Return to head if the flip condition is not satisfied
returnhead; }}}Copy the code
26. Remove duplicates from sorted array
Given a sorted array, you need to remove duplicate elements in place so that each element appears only once, returning the new length of the removed array.
Instead of using extra array space, you must modify the input array in place and do so with O(1) extra space.
Example 1:
Given array nums = [1,1,2],
The function should return a new length of 2, and the first two elements of the original nums array should be changed to 1, 2.
You don’t need to worry about the element after the new length in the array. Example 2:
Given nums = [0,0,1,1,1,2,2,3,3,4],
The function should return a new length of 5, and the first five elements of the original nums array should be changed to 0, 1, 2, 3, 4.
You don’t need to worry about the element after the new length in the array. Description:
Why is the return value an integer, but the output answer is an array?
Note that the input array is passed “by reference,” which means that modifying the input array in a function is visible to the caller.
You can imagine the internal operation as follows:
// Nums is passed by reference. That is, it does not make any copies of the arguments int len = removeDuplicates(nums);
// Modifying the input array in a function is visible to the caller. // Depending on the length returned by your function, it prints out all elements in the array within that length. for (int i = 0; i < len; i++) { print(nums[i]); }
Source: LeetCode link: leetcode-cn.com/problems/re… Copyright belongs to the Collar buckle network. Commercial reprint please contact official authorization, non-commercial reprint please indicate the source.
Double pointer, each encounter different, the value of the right pointer to the left pointer, left and right pointer movement encountered the same, the right pointer to the rightCopy the code
class Solution {
public int removeDuplicates(int[] nums) {
// Use double Pointers
if(nums==null || nums.length == 1) {return nums.length;
}
int i = 0,j =1;
while(j<nums.length){
if(nums[i]==nums[j]){
j++;
}else{ i++; nums[i]=nums[j]; j++; }}return i+1; }}Copy the code
27. Remove elements
Given an array nums and a value val, you remove all elements with a value equal to val in place, returning the new length of the array.
Instead of using extra array space, you must modify the input array in place and do so with O(1) extra space.
The order of elements can be changed. You don’t need to worry about the element after the new length in the array.
Example 1:
Given nums = [3,2,2,3], val = 3,
The function should return a new length of 2, and the first two elements in nums are both 2.
You don’t need to worry about the element after the new length in the array. Example 2:
Given nums = [0,1,2,2,3,0,4,2], val = 2,
The function should return a new length of 5, and the first five elements in nums are 0, 1, 3, 0, 4.
Notice that these five elements can be in any order.
You don’t need to worry about the element after the new length in the array. Description:
Why is the return value an integer, but the output answer is an array?
Note that the input array is passed “by reference,” which means that modifying the input array in a function is visible to the caller.
You can imagine the internal operation as follows:
// Nums is passed by reference. Int len = removeElement(nums, val);
// Modifying the input array in a function is visible to the caller. // Depending on the length returned by your function, it prints out all elements in the array within that length.
for (int i = 0; i < len; i++) {
print(nums[i]);
}
Copy the code
Source: LeetCode link: leetcode-cn.com/problems/re… Copyright belongs to the Collar buckle network. Commercial reprint please contact official authorization, non-commercial reprint please indicate the source.
If they are equal, then I --, which is a loop over the current position to see if they matchCopy the code
class Solution {
public int removeElement(int[] nums, int val) {
int len=nums.length;
int idx=0;
for(int i=0; i<len-idx; i++){if(nums[i]==val){
nums[i]=nums[len-idx-1]; idx++; i--; }}returnlen-idx; }}Copy the code
28. Achieve strStr ()
Implement the strStr() function.
Given a Haystack string and a Needle string, find the first position in the Haystack string where the Needle string appears (starting from 0). If none exists, -1 is returned.
Example 1:
Input: haystack = “hello”, needle = “ll” Output: 2 Example 2
Input: haystack = “aaAAA “, needle = “bba”
What value should we return when needle is an empty string? This is a good question to ask in an interview.
For this case, we should return 0 when needle is an empty string. This is consistent with the C language STRSTR () and the Java definition of indexOf().
Source: LeetCode link: leetcode-cn.com/problems/im… Copyright belongs to the Collar buckle network. Commercial reprint please contact official authorization, non-commercial reprint please indicate the source.
PS: KMP Details (link)
class Solution {
public int strStr(String S, String T) {
if (T == null || T.length() == 0) return 0;
int[] next = new int[T.length()];
getNext(T, next);
int i = 0;
int j = 0;
while (i < S.length() && j < T.length()) {
if (j == -1 || S.charAt(i) == T.charAt(j)) {
i++;
j++;
} else j = next[j];
}
if (j == T.length()) return i - j;
return -1;
}
private void getNext(String t, int[] next) {
next[0] = -1;
int i = 0;
int j = -1;
while (i < t.length() - 1) {
if (j == -1 || t.charAt(i) == t.charAt(j)) { // When matching, move after the same time
i++;
j++;
next[i] = j;
} else {
j = next[j];// If not, find the position before j}}}}Copy the code
29. Divide two numbers
Given two integers, dividend and divisor. Dividing two numbers requires no multiplication, division, and mod operators.
Returns the quotient of dividend divided by divisor.
Example 1:
Input: Dividend = 10, Divisor = 3 Output: 3 Example 2:
Input: Dividend = 7, Divisor = -3 Output: -2 Description:
Both dividend and divisor are 32-bit signed integers. The divisor is not 0. Assume that our environment can store only 32-bit signed integers with values in the range of [−231, 231 − 1]. In this case, 231 − 1 is returned if the division result overflows.
Source: LeetCode link: leetcode-cn.com/problems/di… Copyright belongs to the Collar buckle network. Commercial reprint please contact official authorization, non-commercial reprint please indicate the source.
PS: use logarithms
class Solution {
public int divide(int dividend, int divisor) {
if (divisor == 1) {
return dividend;
}
double dividendDou = (double) dividend;
double divisorDou = (double) divisor;
double logAns = Math.log(Math.abs(dividendDou)) - Math.log(Math.abs(divisorDou));
double answer = Math.exp(logAns);
if ((dividend < 0 && divisor > 0) || (dividend > 0 && divisor < 0)) {
answer = -answer;
}
return (int) answer; }}Copy the code
PS: This method is division
class Solution {
public int divide(int dividend, int divisor) {
if (dividend == 0) {
return 0;
}
if (dividend == Integer.MIN_VALUE && divisor == -1) {
return Integer.MAX_VALUE;
}
boolean negative;
negative = (dividend ^ divisor) <0;// Use xor to calculate whether symbols are different
long t = Math.abs((long) dividend);
long d= Math.abs((long) divisor);
int result = 0;
for (int i=31; i>=0; i--) {if ((t>>i)>=d) {// Find a large enough number 2^n*divisor
result+=1<<i;// Add 2 to the n
t-=d<<i;// Subtract the dividend from 2^n*divisor}}return negative ? -result : result;// the symbol is opposite}}Copy the code
30. String all the words together
Given a string s and some words of the same length. Find the starting position of the substring in S that happens to be formed by concatenating all the words in words.
Note that the substring must match exactly the words in words, without any other characters in the middle, but you do not need to consider the sequence in which words are concatenated.
Example 1:
Input: s = “barfoothefoobarman”, words = [“foo”,”bar”] Output: [0,9] Explanation: Substrings starting from index 0 and 9 are “barfoo” and “foobar”, respectively. The order of the outputs is not important, [9,0] is also a valid answer. Example 2:
Input: s = “wordgoodGoodGoodBestWord “, words = [“word”,”good”,”best”,”word”] output: []
Source: LeetCode link: leetcode-cn.com/problems/su… Copyright belongs to the Collar buckle network. Commercial reprint please contact official authorization, non-commercial reprint please indicate the source.
class Solution {
public List<Integer> findSubstring(String s, String[] words) {
List<Integer> res = new ArrayList<>();
if (s == null || s.length() == 0 || words == null || words.length == 0) return res;
HashMap<String, Integer> map = new HashMap<>();
int one_word = words[0].length();
int word_num = words.length;
int all_len = one_word * word_num;
for (String word : words) {
map.put(word, map.getOrDefault(word, 0) + 1);
}
for (int i = 0; i < one_word; i++) {
int left = i, right = i, count = 0;
HashMap<String, Integer> tmp_map = new HashMap<>();
while (right + one_word <= s.length()) {
String w = s.substring(right, right + one_word);
right += one_word;
if(! map.containsKey(w)) { count =0;
left = right;
tmp_map.clear();
} else {
tmp_map.put(w, tmp_map.getOrDefault(w, 0) + 1);
count++;
while (tmp_map.getOrDefault(w, 0) > map.getOrDefault(w, 0)) {
String t_w = s.substring(left, left + one_word);
count--;
tmp_map.put(t_w, tmp_map.getOrDefault(t_w, 0) - 1);
left += one_word;
}
if(count == word_num) res.add(left); }}}returnres; }}Copy the code