日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

力扣(简单+中等)50题整理总结

發布時間:2023/12/19 编程问答 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 力扣(简单+中等)50题整理总结 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • 前言
  • 一、簡單題
    • 1. 兩數之和
    • 7. 整數反轉
    • 9. 回文數
    • 13. 羅馬數字轉整數
    • 14. 最長公共前綴
    • 20. 有效的括號
    • 21. 合并兩個有序鏈表
    • 26. 刪除有序數組中的重復項
    • 27. 移除元素
    • 28. 實現 strStr()
    • 35. 搜索插入位置
    • 38. 外觀數列
    • 53. 最大子序和
    • 58. 最后一個單詞的長度
    • 66. 加一
    • 70. 爬樓梯
    • 101. 對稱二叉樹
    • 110. 平衡二叉樹
    • 118. 楊輝三角
    • 217. 存在重復元素
    • 219. 存在重復元素 II
    • 283. 移動零
    • 509. 斐波那契數
    • 643. 子數組最大平均數 I
    • 976. 三角形的最大周長
    • 1137. 第 N 個泰波那契數
  • 二、中等題
    • 2. 兩數相加
    • 3. 無重復字符的最長子串
    • 5. 最長回文子串
    • 6. Z 字形變換
    • 8. 字符串轉換整數 (atoi)
    • 17. 電話號碼的字母組合
    • 46. 全排列
    • 62. 不同路徑
    • 73. 矩陣置零
    • 94. 二叉樹的中序遍歷
    • 130. 被圍繞的區域
    • 144. 二叉樹的前序遍歷
    • 145. 二叉樹的后序遍歷
    • 198. 打家劫舍
    • 200. 島嶼數量
    • 445. 兩數相加 II
    • 486. 預測贏家
    • 503. 下一個更大元素 II
    • 567. 字符串的排列
    • 877. 石子游戲
  • 總結


前言

???????從第一次進入力扣,和朋友們琢磨著第一題的兩數之和,到現在玩力扣有一個多學期了。雖然沒有系統的訓練,但還是見識到了一些基礎的算法。先把做過的題總結了,然后接下來就撿一些重點算法去打。


一、簡單題

1. 兩數之和

方法:暴力,快慢指針

class Solution {public int[] twoSum(int[] nums, int target) {int[] ans = new int[2];for (int i = 0;i < nums.length;++i){for (int j = i + 1;j < nums.length;++j) {if(nums[j] == target-nums[i]) {ans[0] = i;ans[1] = j;return ans;}}}return ans;} }

7. 整數反轉

方法:一位一位反轉(注意:判斷溢出)

class Solution {public int reverse(int x) {int ans = 0;while (x != 0) {// 判斷當前值是否溢出if ((ans * 10) / 10 != ans) {ans = 0;break;}// 反轉當前位ans = ans * 10 + x % 10;x = x / 10;}return ans;} }

9. 回文數

方法:反轉此數,判斷反轉前后是否相等

class Solution {public boolean isPalindrome(int x) {if (x < 0){// 負數直接返回falsereturn false;}int ans = 0, m = x;while (m != 0) {// 反轉x為ansans = ans * 10 + m % 10;m = m / 10;}if (x == ans){return true;}else{return false;}} }

13. 羅馬數字轉整數

方法:循環嵌套switch開關,選擇對應的轉換值

class Solution { public:int romanToInt(string s) {int ans = 0;for (int i = 0;i<s.size();i++) {switch (s[i]){case 'I': {if (s[i + 1] == 'V') { ans += 4; i++; break; }if (s[i + 1] == 'X') { ans += 9; i++; break; }ans += 1; }break;case 'V':ans += 5; break;case 'X': {if (s[i + 1] == 'L') { ans += 40; i++; break; }if (s[i + 1] == 'C') { ans += 90; i++; break; }ans += 10;}break;case 'L':ans += 50; break;case 'C': {if (s[i + 1] == 'D') { ans += 400; i++; break; }if (s[i + 1] == 'M') { ans += 900; i++; break; }ans += 100;}break;case 'D':ans += 500; break;case 'M':ans += 1000; break;}}return ans;} };

14. 最長公共前綴


方法:按住第一個串,將其逐個字符與后面的串中對應下標字符比較
注意:當首串當前字符下標與后面某個串的串長相等時,即可不再比較

class Solution {public String longestCommonPrefix(String[] strs) {if (strs == null || strs.length == 0) {return "";}for (int i = 0; i < strs[0].length(); ++i){// 按住第一個串char c = strs[0].charAt(i);for (int j = 1;j < strs.length; ++j){// 將其與后面的串縱向比較if (i == strs[j].length() || strs[j].charAt(i) != c){return strs[0].substring(0, i);}}}return strs[0];} }

20. 有效的括號


方法:左括號逐個進棧,右括號逐個與棧頂左括號匹配

關鍵點:

  • 以棧的形式使用Deque(java)
  • 當左括號比右括號多時,匹配結束棧不為空
  • class Solution {public boolean isValid(String s) {Deque<Character> stack = new LinkedList<>();for (int i = 0; i < s.length(); ++i){// 若是左括號"(", "[", "{", 入棧 if (s.charAt(i) == '(' || s.charAt(i) == '[' || s.charAt(i) == '{'){stack.push(s.charAt(i));}// 若是右括號")", "]", "}", 判斷后出棧 if (s.charAt(i) == ')'){if (!stack.isEmpty() && stack.peek() == '('){stack.pop();}else{return false;}}else if (s.charAt(i) == ']'){if (!stack.isEmpty() && stack.peek() == '['){stack.pop();}else{return false;}}else if (s.charAt(i) == '}'){if (!stack.isEmpty() && stack.peek() == '{'){stack.pop();}else{return false;}}}// 若左括號比右括號多,則不匹配,即棧不為空return stack.isEmpty();} }

    21. 合并兩個有序鏈表


    方法:雙指針+啞元

    class Solution { public:ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) {ListNode *ehead=new ListNode;//啞節點ehead(頭節點) ListNode *e=ehead;while(l1&&l2){ //l1在第一條鏈移動,l2在第二條鏈移動if(l1->val<=l2->val){e->next=l1;l1=l1->next;}else{e->next=l2;l2=l2->next;} e=e->next;}e->next = l1 == nullptr ? l2 : l1; //連接后續節點ehead=ehead->next; //去啞節點return ehead;} };

    26. 刪除有序數組中的重復項


    方法:快慢指針

    關鍵點:

  • 快指針負責跳過重復元素
  • 慢指針負責把不重復的元素記錄在數組前端
  • class Solution { public:int removeDuplicates(vector<int>& nums) {if(nums.size()==0)return 0;int i=0,j,flag=1;for(j=i+1;j<=nums.size()-1;++j){//j慢指針,i快指針if(nums[j]<=nums[i])continue;else {nums[++i]=nums[j];flag++;//有賦值則標記加1}}return flag;} };

    27. 移除元素



    方法:快慢指針

    關鍵點:

  • 慢指針負責找目標val值
  • 快指針負責將val值移動到數組后端
  • class Solution {public int removeElement(int[] nums, int val) {int i = 0, flag;for (; i<nums.length; ++i){//慢指針遍歷數組if (nums[i] == val) {//如果出現val值,動用快指針flag=1;for (int j = i; flag==1 && j < nums.length; ++j)//快指針if (nums[j] != val) {//搜索第一個與val值不同的元素,兩者交換int temp = nums[j];nums[j] = nums[i];nums[i] = temp;flag = 0;}if (flag == 1)break;//如果快指針一趟循環后無交換,意味數組已成型}}return i;//慢指針移動次數=新數組長度} }

    28. 實現 strStr()


    關鍵點(滑動窗口):

  • 維護窗口起始位start
  • 使用substring截斷進行比較
  • public class Solution {public int strStr(String haystack, String needle) {int n = needle.length();int h = haystack.length();for (int start = 0; start < h - n + 1; start++) { // 維護長度n的窗口if (haystack.substring(start, start + n).equals(needle)) {return start;}}return -1;} }

    35. 搜索插入位置


    方法:暴力

    class Solution {public int searchInsert(int[] nums, int target) {for (int i = 0; i < nums.length; ++i){if (nums[i] < target){continue;}else{return i;}}return nums.length;} }

    38. 外觀數列


    class Solution {public String countAndSay(int n) {// 遞歸終止條件if (n == 1) {return "1";}// 獲取到上一層的字符串String s = countAndSay(n - 1);StringBuilder result = new StringBuilder();// 記錄每個數字的開始索引int start = 0;for (int i = 1; i < s.length(); i++) {// 當數字發生改變時執行if (s.charAt(i) != s.charAt(start)) {result.append(i - start).append(s.charAt(start));start = i;}}// 字符串最后一個數字result.append(s.length() - start).append(s.charAt(start));return result.toString();} }

    53. 最大子序和


    關鍵點(動態規劃):

  • pre維護的窗口的含義
  • class Solution {public int maxSubArray(int[] nums) {int pre = 0, maxAns = nums[0];for (int x : nums) {pre = Math.max(pre + x, x);// pre維護一個滑窗的子序和(正整數)maxAns = Math.max(maxAns, pre);// 挑選pre滑過的子序和中最大的一個}return maxAns;} }

    58. 最后一個單詞的長度


    方法:暴力

    class Solution {public int lengthOfLastWord(String s) {int count = 0;s = s.toLowerCase();for (int i = s.length() - 1; i >= 0; --i){if (s.charAt(i) >= 'a' && s.charAt(i) <= 'z'){// 計算字母數量count++;}else if (count > 0){// 從第一個不屬于最后一個單詞的字母的字符截斷break; }}return count;} }

    66. 加一


    關鍵點(暴力):

  • 因為是加1,固不進位即可返回
  • 溢出需構建長度為原數組長度+1的新數組,首元素初始化為1即可
  • class Solution {public int[] plusOne(int[] digits) {for (int i = digits.length - 1; i >= 0; i--) {digits[i]++;// 加一或進位digits[i] = digits[i] % 10;// 保證數組元素為單位數if (digits[i] != 0) return digits;// 無進位,返回}digits = new int[digits.length + 1];// 循環結束證明溢出,構建新數組digits[0] = 1;return digits;} }

    70. 爬樓梯


    關鍵點(動態規劃):方程 F(n)= F(n - 1)- F(n - 2)

    class Solution {public int climbStairs(int n) {int p = 0, q = 0, r = 1;for (int i=0; i<n; ++i){// 滾動數組p = q;// 記錄n-2的狀態q = r;// 記錄n-1的狀態r = p + q;// 動態規劃方程:f(n)=f(n-1)+f(n-2)}return r;} }

    101. 對稱二叉樹


    關鍵點(雙指針):

  • 遞歸的傳參方式:check(p.left, q.right) && check(p.right, q.left)
  • 遞歸的出口判斷:&& 要在 || 前面,幫 || 過濾兩個節點都是空的情況
  • class Solution {public boolean isSymmetric(TreeNode root) {return check(root, root);}public boolean check(TreeNode p, TreeNode q) {// 如果傳來的兩個節點都為空,則兩個父節點都沒有這個對稱位上的子節點,對稱if (p == null && q == null) { return true;}// 如果只有一個節點為空,則兩個父節點中只有一個存在此子節點,則不對稱if (p == null || q == null) { return false;}// 如果都不為空,則將比較當前節點值val得出的結果與下一次遞歸返回結果做&&return p.val == q.val && check(p.left, q.right) && check(p.right, q.left);} }

    110. 平衡二叉樹


    關鍵點:
    在計算二叉樹的算法基礎上加判斷:兩個子樹的高度絕對值是否滿足題目定義。

    class Solution {public boolean isBalanced(TreeNode root) {return hightree(root) != -1;}public static int hightree(TreeNode root) {int H, H1, H2;if (root == null){H = 0;}else {H1 = hightree(root.left);H2 = hightree(root.right);if (H1 == -1 || H2 == -1){// 兩個子樹都不滿足,直接返回return -1;}if (Math.abs(H1 - H2) > 1){// 用高度平衡二叉樹的定義作判斷return -1;}H = (H1 > H2 ? H1 : H2) + 1;}return H;} }

    118. 楊輝三角

    關鍵點:

  • 找規律
  • 每次構建answer時需重新分配其內存
  • 沒有搞懂第二點為什么不能用List.clear()代替
  • class Solution {public List<List<Integer>> generate(int numRows) {List<List<Integer>> answers = new ArrayList<List<Integer>>();for (int i = 0; i < numRows; ++i){List<Integer> answer = new ArrayList<>();for (int j = 0; j <= i; ++j){if (j == 0 || j == i){answer.add(1);}else{answer.add(answers.get(i - 1).get(j - 1) + answers.get(i - 1).get(j));}}answers.add(answer);//answer.clear();}return answers;} }

    217. 存在重復元素


    關鍵點:Set中不能添加重復元素

    class Solution {public boolean containsDuplicate(int[] nums) {Set<Integer> set = new HashSet<Integer>();for (int x : nums){if (!set.add(x)){return true;}}return false;} }

    219. 存在重復元素 II


    關鍵點(滑動窗口):

  • 用Set作為滑動窗口,若窗口內存在重復元素,則true
  • 前進右窗:add(nums【i】),前進左窗:remove(nums【i - k】)
  • class Solution {public boolean containsNearbyDuplicate(int[] nums, int k) {Set<Integer> set = new HashSet<Integer>();for(int i = 0; i < nums.length; ++i) {if (set.contains(nums[i])) {return true;}set.add(nums[i]);// 前進右窗口if (set.size() > k) {set.remove(nums[i - k]);// 前進左窗口}}return false;} }

    283. 移動零


    關鍵點(雙指針):

  • 一次循環代替兩次,將復雜度O(n^2)降O(n)
  • 快指針前進的條件:遇到0或完成一次賦值
  • class Solution {public void moveZeroes(int[] nums) {int a = 0, b = 0;// 慢指針a,快指針bwhile (b < nums.length) {if (nums[b] == 0){// 快指針b遇到0就跳b++;continue;}nums[a++] = nums[b++];// a、b完成一次賦值就跳}while (a < b) { // 填補尾部的0nums[a++] = 0;}} }

    509. 斐波那契數


    (略)

    int fib(int N){if(N==0)return 0;if(N==1)return 1;return fib(N-1)+fib(N-2); }

    643. 子數組最大平均數 I


    關鍵點(滑動窗口):

  • 維護一個長度為k的窗口,在每次移動此窗口前,求窗口內元素平均值,取Max
  • class Solution {public double findMaxAverage(int[] nums, int k) {double sum = 0, maxAvg = 0;for (int i = 0; i < nums.length; ++i) {sum += nums[i];// 前進右窗口if (i == k - 1){maxAvg = sum / k;}if (i >= k){sum -= nums[i - k];// 前進左窗口maxAvg = Math.max(sum / k, maxAvg);// 求最大平均數}}return maxAvg;} }

    976. 三角形的最大周長


    方法:排序、按順序找符合條件的三角形,其周長即為數組內最大

    class Solution {public int largestPerimeter(int[] A) {Arrays.sort(A);// 從大到小排序for (int i = A.length - 1; i >= 2; --i) {if (A[i - 2] + A[i - 1] > A[i]) { // 用三角形定義逐個判斷return A[i - 2] + A[i - 1] + A[i];}}return 0;} }

    1137. 第 N 個泰波那契數


    方法:動態規劃

    int tribonacci(int n) {if (n < 3)return n==0?0:1;int x=0, y=1, z=1, tep;for(int i=0;i<n-2;++i){tep=x+y+z;x=y;y=z;z=tep;}return z; }


    二、中等題

    2. 兩數相加


    關鍵點:雙指針,尾插,補零相加

    class Solution {public ListNode addTwoNumbers(ListNode l1, ListNode l2) {ListNode head = null,tail = null; // 初始化返回鏈頭尾為nullint carry = 0; // 初始化進位符while (l1 != null || l2 != null){ int s1 = l1 == null ? 0 : l1.val; // 兩個鏈表都為null時停止int s2 = l2 == null ? 0 : l2.val; // 只有一條鏈為null則將另外一條鏈對應位補零int sum = s1 + s2 + carry; // 計算當前和if (head == null){ // 分配頭尾節點的空間head = tail = new ListNode(sum % 10);}else{ // 尾插鏈節點,tail永遠指向最后的節點tail.next = new ListNode(sum % 10);tail = tail.next;}carry = sum / 10; // 計算進位// 前進鏈1指針if (l1 != null){ l1 = l1.next;}// 前進鏈2指針if (l2 != null){ l2 = l2.next;}}// 溢出則補齊最高if (carry > 0){tail.next = new ListNode(1);}return head; // 返回鏈頭} }

    3. 無重復字符的最長子串

    關鍵點(滑動窗口):

  • 右窗口臨近元素的加入條件:!occ.contains(s.charAt(rk + 1))
  • 左窗口移除元素的邏輯:剛好不包含rk+1處的重復元素
  • class Solution {public int lengthOfLongestSubstring(String s) {// HashSet,不可加入重復的元素Set<Character> occ = new HashSet<Character>();int n = s.length();int rk = -1, ans = 0;for (int i = 0; i < n; ++i) {if (i != 0) {// 左窗口向右移除一個字符,跳過下面while繼續進行for,直至窗口剛好不包含當前重復元素occ.remove(s.charAt(i - 1));}// 判斷rk+1是否大于n,以及HashSet中是否存在字符串rk+1處的字符while (rk + 1 < n && !occ.contains(s.charAt(rk + 1))) {// 加入HashSet,前進右窗口occ.add(s.charAt(rk + 1));++rk;}// 第 i 到 rk 個字符是一個極長的無重復字符子串,從這些極長的子串中Max一個最長子串ans = Math.max(ans, rk - i + 1);}return ans;} }

    5. 最長回文子串

    關鍵點(動態規劃):

  • dp的填表方向:列自左往右,行自上往下
  • 獲取更大的回文子串判斷條件:j - i + 1 > ans.length()
  • class Solution {public static String longestPalindrome(String s) {if (s.length() <= 1)return s; // 若串長小于等于1,返回原串boolean[][] dp = new boolean[s.length()][s.length()];String ans = "";for (int i = 0;i < s.length();++i){// 初始化dp數組對角線dp[i][i] = true;}ans = s.substring(1, 2);// 假設接下來沒有找到回文子串,則返回此處初始化為首字符的ansfor (int j = 1;j < s.length();++j){// 填表,列從左往右for (int i = 0;i < j;++i){// 行從上往下if (j == i + 1){// 對于長度為2的串,判斷其是否為回文串dp[i][j] = s.charAt(i)==s.charAt(j);}else{// 對于其他串,結合dp表以及當前兩個端點元素是否相等進行判斷dp[i][j] = (s.charAt(i)==s.charAt(j) && dp[i + 1][j - 1]);}// 獲取更大的回文子串if (dp[i][j] && j - i + 1 > ans.length()){ans = s.substring(i, j + 1);}}}return ans;} }

    6. Z 字形變換

    關鍵點:找規律( 詳情見 Z字形變換(LeetCode第6題))

    class Solution { public:string convert(string s, int numRows) {if (numRows == 1)return s;string ans("");int down = 2 * numRows - 4, up = 2;//設置up、down的初值for (int i = 0; i < numRows; i++) {int k = i,flag = 1;//第一行和最后一行的循環if (i == 0 || i == numRows - 1) {while (k < s.size()) {ans+=s[k];k = k + 2*numRows-2;}continue;}//中間行(第一行和最后一行之間的行)的循環elsewhile (k < s.size()) {ans += s[k];flag++ % 2 == 1 ? k = k+down : k = k+up;//用flag判斷每次循環讀取需跳躍的值}down -= 2;up += 2;//每結束一次中間行的循環up和down要變一次}return ans;} };

    8. 字符串轉換整數 (atoi)

    方法:有限狀態機(不是很會,抄的題解,知道有這回事)

    class Solution {public int myAtoi(String str) {Automaton automaton = new Automaton();int length = str.length();for (int i = 0; i < length; ++i) {automaton.get(str.charAt(i));}return (int) (automaton.sign * automaton.ans);} }class Automaton {public int sign = 1;public long ans = 0;private String state = "start";private Map<String, String[]> table = new HashMap<String, String[]>() {{put("start", new String[]{"start", "signed", "in_number", "end"});put("signed", new String[]{"end", "end", "in_number", "end"});put("in_number", new String[]{"end", "end", "in_number", "end"});put("end", new String[]{"end", "end", "end", "end"});}};public void get(char c) {state = table.get(state)[get_col(c)];if ("in_number".equals(state)) {ans = ans * 10 + c - '0';ans = sign == 1 ? Math.min(ans, (long) Integer.MAX_VALUE) : Math.min(ans, -(long) Integer.MIN_VALUE);} else if ("signed".equals(state)) {sign = c == '+' ? 1 : -1;}}private int get_col(char c) {if (c == ' ') {return 0;}if (c == '+' || c == '-') {return 1;}if (Character.isDigit(c)) {return 2;}return 3;} }

    17. 電話號碼的字母組合


    關鍵點(dfs+狀態重置):

  • Map、StringBuffer類型的使用
  • 當dfs層數到達號碼串長時,剪枝
  • class Solution {public List<String> letterCombinations(String digits) {List<String> answers = new ArrayList<String>();if (digits.length() == 0) {return answers;}// 初始化Map為號碼與字母串的映射Map<Character, String> phoneMap = new HashMap<Character, String>() {{put('2', "abc");put('3', "def");put('4', "ghi");put('5', "jkl");put('6', "mno");put('7', "pqrs");put('8', "tuv");put('9', "wxyz");}};dfs(answers, phoneMap, digits, 0, new StringBuffer());return answers;}public void dfs(List<String> answers, Map<Character, String> phoneMap, String digits, int deepth, StringBuffer path) {if (deepth == digits.length()) {answers.add(path.toString());} else {char digit = digits.charAt(deepth);// 獲取此層號碼String letters = phoneMap.get(digit);// 獲取此號碼映射的字母串for (int i = 0; i < letters.length(); i++) {// 按號碼映射的字母串的順序將字母加入路徑(入棧)path.append(letters.charAt(i));// dfs搜索下一層dfs(answers, phoneMap, digits, deepth + 1, path);// 狀態重置(出棧)path.deleteCharAt(deepth);}}} }

    46. 全排列


    關鍵點(dfs):狀態變量,狀態重置,以棧的形式使用Deque(java)

    class Solution {public List<List<Integer>> permute(int[] nums) {List<List<Integer>> res=new ArrayList<>();if (nums.length==0){return res;}//狀態變量path(棧),used[],deepthDeque<Integer> path=new ArrayDeque<>();boolean[] used=new boolean[nums.length];int deepth=0;dfs(nums,res,path,used,deepth);return res;}private void dfs(int[] nums,List<List<Integer>> res,Deque<Integer> path,boolean[] used,int deepth) {if(deepth==nums.length){//“剪枝”res.add(new ArrayList<>(path));return;}for(int i=0;i<nums.length;++i){if(used[i]==true){continue;}path.addLast(nums[i]);used[i]=true;dfs(nums,res,path,used,deepth+1);path.removeLast();//狀態重置used[i]=false;}} }

    62. 不同路徑


    關鍵點(動態規劃):

  • 先填首行與首列
  • 再依次列從左往右,行從上往下填表
  • class Solution {public int uniquePaths(int m, int n) {int[][] dp=new int[m][n];for(int i=0;i<m;++i){//首行dp[i][0]=1;}for(int i=0;i<n;++i){//首列dp[0][i]=1;}for(int i=1;i<m;++i){//填表for(int j=1;j<n;++j){dp[i][j]=dp[i-1][j]+dp[i][j-1];}}return dp[m-1][n-1];} }

    73. 矩陣置零


    關鍵點:行列標記數組,先標記再替換

    class Solution {public void setZeroes(int[][] matrix) {int m = matrix.length, n = matrix[0].length;boolean[] row = new boolean[m];boolean[] col = new boolean[n];for (int i = 0; i < m; i++) {// 標記for (int j = 0; j < n; j++) {if (matrix[i][j] == 0) {row[i] = col[j] = true;}}}for (int i = 0; i < m; i++) {// 替換for (int j = 0; j < n; j++) {if (row[i] || col[j]) {matrix[i][j] = 0;}}}} }

    94. 二叉樹的中序遍歷


    (數據結構基礎)

    class Solution {public List<Integer> inorderTraversal(TreeNode root) {List<Integer> answer=new ArrayList();if(root==null)return answer;PT(answer,root);return answer;}public void PT(List<Integer> answer,TreeNode root){if(root.left!=null)PT(answer,root.left);answer.add(root.val);if(root.right!=null)PT(answer,root.right)} }

    130. 被圍繞的區域

    關鍵點(dfs):

  • 從上下左右四個方向深度優先搜索邊界的O以及與其相連的O,并替換成‘#’
  • 填充所有未被搜索到的O(被圍繞的O),再將#還原為O(邊界O)
  • class Solution {public void solve(char[][] board) {if (board == null || board.length == 0) return;int m = board.length;int n = board[0].length;for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {// 從邊緣o開始搜索boolean isEdge = i == 0 || j == 0 || i == m - 1 || j == n - 1;if (isEdge && board[i][j] == 'O') {dfs(board, i, j);}}}for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {if (board[i][j] == 'O') {// 將被圍繞的O填充board[i][j] = 'X';}if (board[i][j] == '#') {// 將邊界的O還原board[i][j] = 'O';}}}}public void dfs(char[][] board, int i, int j) {if (i < 0 || j < 0 || i >= board.length || j >= board[0].length || board[i][j] == 'X' || board[i][j] == '#') {// board[i][j] == '#' 說明已經搜索過了. return;}board[i][j] = '#';dfs(board, i - 1, j); // 上dfs(board, i + 1, j); // 下dfs(board, i, j - 1); // 左dfs(board, i, j + 1); // 右} }

    144. 二叉樹的前序遍歷


    (數據結構基礎)

    class Solution {public List<Integer> preorderTraversal(TreeNode root) {List<Integer> answer=new ArrayList();if(root==null)return answer;PT(answer,root);return answer;}public void PT(List<Integer> answer,TreeNode root){answer.add(root.val);if(root.left!=null)PT(answer,root.left);if(root.right!=null)PT(answer,root.right);} }

    145. 二叉樹的后序遍歷


    (數據結構基礎)

    class Solution {public List<Integer> postorderTraversal(TreeNode root) {List<Integer> answer=new ArrayList();if(root==null)return answer;PT(answer,root);return answer;}public void PT(List<Integer> answer,TreeNode root){if(root.left!=null)PT(answer,root.left);if(root.right!=null)PT(answer,root.right);answer.add(root.val);} }

    198. 打家劫舍

    關鍵點(動態規劃):

  • 狀態轉移方程:dp[i]=max(dp[i?2]+nums[i],dp[i?1])
  • 邊界條件:dp[0]=nums[0],dp[1]=max(nums[0],nums[1])
    ?
  • class Solution {public int rob(int[] nums) {if(nums.length==0)return 0;if(nums.length==1)return nums[0];if(nums.length==2)return Math.max(nums[0],nums[1]);int[] dp=new int[nums.length];dp[0]=nums[0];// 只有一個房子dp[1]=Math.max(nums[0],nums[1]);// 只有兩個房子for(int i=2;i<nums.length;++i){dp[i]=Math.max(dp[i-2]+nums[i],dp[i-1]);}return dp[nums.length-1];} }

    ?


    200. 島嶼數量


    思路:

  • 遍歷二維數組,遇到1,島嶼數量+1
  • DFS將與其連起來的1替換成0,退出DFS繼續遍歷二維數組
  • class Solution {public int numIslands(char[][] grid) {int num_Islands=0;for(int i=0;i<grid.length;++i){for(int j=0;j<grid[0].length;++j){if(grid[i][j]=='1'){// 遇到1++num_Islands;dfs(grid,i,j);}}}return num_Islands;}public void dfs(char[][] grid,int i,int j){if(i<0||j<0||i>grid.length-1||j>grid[0].length-1||grid[i][j]=='0'){return;// 越界則返回}grid[i][j]='0';// 替換0dfs(grid,i-1,j);// 上dfs(grid,i+1,j);// 下dfs(grid,i,j-1);// 左dfs(grid,i,j+1);// 右} }

    445. 兩數相加 II

    關鍵點(棧):

  • 保證位數對齊:將兩個數的每個位數都分別入棧,然后從兩個棧頂開始相加
  • class Solution {public ListNode addTwoNumbers(ListNode l1, ListNode l2) {Deque<Integer> s1=new ArrayDeque<>();while (l1 != null) {// 入棧s1.addLast(l1.val);l1 = l1.next;}Deque<Integer> s2 = new ArrayDeque<>();while (l2 != null) {// 入棧s2.addLast(l2.val);l2 = l2.next;}ListNode answer = new ListNode(0);int carry = 0;while (!s1.isEmpty() || !s2.isEmpty()) {int sum = (s1.isEmpty() ? 0 : s1.removeLast())+(s2.isEmpty() ? 0 : s2.removeLast()) + carry;// 出棧ListNode newnode = new ListNode(sum % 10);newnode.next = answer.next;// 頭插answer.next = newnode;if (sum >= 10){carry = sum/10;}else{carry = 0;}}if (carry != 0) {// 若還有進位ListNode newnode = new ListNode(1);newnode.next = answer.next;answer.next = newnode;}return answer.next;} }

    486. 預測贏家


    關鍵點(動態規劃):

  • 先設計暴力解法,再用dp數組記錄重復運算進行優化
  • class Solution {public boolean PredictTheWinner(int[] nums) {int[][] dp=new int[nums.length][nums.length];for(int i=0;i<nums.length;++i){dp[i][i]=nums[i];//初始化dp表的對角線}for(int i=nums.length-2;i>=0;--i){for(int j=i+1;j<=nums.length-1;++j){dp[i][j]=Math.max(nums[i]-dp[i+1][j],nums[j]-dp[i][j-1]);//填表,計算所有子問題的凈勝分}}return dp[0][nums.length-1]>=0;//得出結果(最終凈勝分是否大于等于0)} } /*優化前的暴力解法,遞歸中含有重復子問題public boolean PredictTheWinner(int[] nums) {return Thinking(nums,0,nums.length-1)>=0;}public int Thinking(int[] nums,int start,int end) {if(start==end){return nums[start];}int choseleft=nums[start]-Thinking(nums,start+1,end);//選左的凈勝分int choseright=nums[end]-Thinking(nums,start,end-1);//選右的凈勝分return Math.max(choseleft,choseright);//返回一個高的凈勝分} */

    503. 下一個更大元素 II


    (暴力,單調棧為更優解)

    //暴力 class Solution {public int[] nextGreaterElements(int[] nums) {int[] ans=new int[nums.length];//用nums初始化新數組ansfor(int n=0;n<nums.length;++n){int count=0;for(int i=(n+1)%nums.length;i<nums.length;i=(i+1)%nums.length){if(++count>=nums.length){//找不到ans[n]=-1;break;}if(nums[n]<nums[i]){//找到ans[n]=nums[i];break;}}}return ans;} }

    567. 字符串的排列


    關鍵點(滑動窗口):

  • 用長度為26的一維數組維護一個滑動窗口
  • 窗口在l2滑動的過程,只要滿足窗口內各字母數量與l1內各字母數相符,即匹配成功
  • class Solution {public boolean checkInclusion(String s1, String s2) {if (s1.length() > s2.length())return false;//因為字符串都是a-z的字母,所以我們可以使用一個長度為26的int數組來存儲每個字母出現的個數int[] s1map = new int[26];int[] s2map = new int[26];for (int i = 0; i < s1.length(); i++) {//這里char類型加減使用Ascii碼,-'a'正好對應a-z在數組中的索引,值為該字母出現的次數s1map[s1.charAt(i) - 'a']++;s2map[s2.charAt(i) - 'a']++;}//滑動窗口//窗口大小為s1.length,索引從[0 —— s1.length-1]到[s2.length-s1.length —— s2.length-1]for (int i = 0; i < s2.length() - s1.length(); i++) {//如果匹配,直接返回if (isMatch(s1map, s2map)) {return true;}//如果不匹配,窗口向后移動一位//窗口加入下一個字母s2map[s2.charAt(i + s1.length()) - 'a']++;//窗口移除第一個字母s2map[s2.charAt(i) - 'a']--;}//最后比較i = s2.length-s1.length的情況return isMatch(s1map,s2map);}/*** 這里兩個數組的長度都為26* @param charArray1* @param charArray2* @return*/private static boolean isMatch(int[] charArray1,int[] charArray2 ){for (int i = 0; i < charArray1.length; i++) {//這里只要出現一個字母個數不一樣,就直接返回falseif (charArray1[i] != charArray2[i]) {return false;}}return true;} }

    877. 石子游戲


    (預測贏家的同類題,此處可用數學解,略)

    class Solution {public boolean stoneGame(int[] piles) {return true;} } //dp法見 486.預測贏家

    總結

    ???????認識了很多算法,像動態規劃、滑動窗口、Dfs、回溯、雙指針…認識了很多數據結構,像Java的Set、Deque、ArrayList、LinkedList…

    ???????我身邊有很多人,參加過很多競賽,獲得過很多榮譽。有人問過我說:他們各方面都比你優秀,努力程度也不比你差,為啥還要努力?我說,有意義的是過程,結果是大家都看得到的,只有過程是真正屬于自己的,即使未來不青睞我,我也要繼續,因為:

    ???????“強大者應持謙卑之心不可因力量而跋扈,
    ???????????????弱小者應持上進之心不可因不敵而麻木。”

    繼續打題、繼續前進…
    (未完待續)

    總結

    以上是生活随笔為你收集整理的力扣(简单+中等)50题整理总结的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    视色网站 | 人人干人人超 | 丁香久久激情 | 狠狠干天天 | 视频一区二区精品 | 国产精品久久久久久一区二区三区 | 91精品国产91久久久久久三级 | 免费观看一级特黄欧美大片 | 色综合天天狠狠 | 色综合天天综合在线视频 | 精品一区二区三区香蕉蜜桃 | 精品亚洲视频在线观看 | 一本色道久久综合亚洲二区三区 | 亚洲精品乱码久久久久久9色 | 午夜美女影院 | 国产不卡在线播放 | 欧美日bb| 国产精品久久久久久麻豆一区 | 久久精品亚洲国产 | 精品一区二区在线免费观看 | 成人毛片一区二区三区 | 国产精品99久久久久久武松影视 | 西西444www大胆高清图片 | 热久久免费国产视频 | 亚洲蜜桃在线 | 丁香六月中文字幕 | 成人h视频在线播放 | 亚洲精品自拍视频在线观看 | 日本三级中文字幕在线观看 | 91av视频导航| 天天操天天射天天 | 久久不卡电影 | 久久久久久久久久久影院 | 999精品网 | 色综合天天综合网国产成人网 | 国产91丝袜在线播放动漫 | 日本午夜在线亚洲.国产 | 97视频在线免费观看 | 国产免费国产 | 国产精品视频永久免费播放 | 欧美va在线观看 | 久久,天天综合 | 国产精品高潮呻吟久久av无 | 久久视频在线 | 日本久久精品 | 久久久国产精品人人片99精片欧美一 | 国产视频2 | 国产一级片网站 | 亚洲一区欧美激情 | 麻豆免费视频 | 97精品超碰一区二区三区 | 国产美女精品在线 | 久久综合久久综合久久 | 色偷偷av男人天堂 | av在线播放国产 | 一区二区三区中文字幕在线观看 | 亚洲天堂视频在线 | 99热在线看 | 天天躁日日躁狠狠躁 | 日韩精品一区二区三区不卡 | 欧美做受高潮1 | 日日日日 | 国产麻豆剧传媒免费观看 | av在线最新 | 中文伊人 | 在线观看国产中文字幕 | 69国产精品视频免费观看 | 特级毛片在线 | 美女黄网站视频免费 | 1024手机在线看 | 中文字幕在线观看第三页 | 中文字幕在线播放一区 | 中文字幕在线一区观看 | 玖玖玖在线 | 日韩一级片网址 | 色婷婷 亚洲| 亚洲色视频 | 丁香婷婷激情国产高清秒播 | 久久国产热 | 中文字幕在线日亚洲9 | 色av男人的天堂免费在线 | 久草资源在线观看 | 亚洲综合在线视频 | 午夜 在线 | 久草免费在线观看视频 | 成人欧美日韩国产 | 成人久久久电影 | 国产在线黄色 | 久久激情视频免费观看 | 成人一级电影在线观看 | 国产色资源 | 国产69精品久久久久久久久久 | 国产明星视频三级a三级点| 国产99区 | 久久电影中文字幕视频 | 在线观看中文字幕dvd播放 | 贫乳av女优大全 | 免费在线播放av电影 | 国内精品免费久久影院 | 蜜臀aⅴ国产精品久久久国产 | 亚洲成人av一区 | 国内精品久久天天躁人人爽 | 91久久精品一区 | 久久网站av| 91日韩在线播放 | 99re8这里有精品热视频免费 | 欧美性性网 | www.av中文字幕.com | 成人黄色在线观看视频 | www.狠狠色.com | 在线精品视频免费播放 | 丁香六月婷婷开心婷婷网 | 国产高清视频免费 | www亚洲精品 | 综合天堂av久久久久久久 | 最近免费在线观看 | 久久久九色精品国产一区二区三区 | 韩国在线一区 | 精品综合久久久 | 免费国产一区二区 | 精品国产一区二区三区免费 | 夜夜天天干 | 国产精品午夜在线 | 久草电影在线观看 | 国内精品久久久久久久久久久久 | 欧美在线观看视频一区二区三区 | 日本高清免费中文字幕 | 波多野结衣小视频 | 午夜一级免费电影 | 久久色中文字幕 | 在线视频 精品 | 精品一区精品二区高清 | 成人午夜网 | 丁香六月欧美 | 不卡av电影在线 | 国产精品国产三级在线专区 | 日韩理论在线播放 | 欧美激情一区不卡 | 久久久久麻豆v国产 | 久久成人午夜视频 | 中文字幕免费观看全部电影 | 亚洲人成在线观看 | 91福利社在线观看 | 国产成人一区二区三区免费看 | 久久99视频免费 | 91人人澡人人爽人人精品 | a在线观看国产 | 99久久精品国产系列 | 日韩av影视在线观看 | 日韩欧美99| 综合久久久久久久久 | 精品国产乱码久久久久久天美 | 日韩女同av | 欧美激情精品久久久久久 | 天天操综合网站 | 天天综合久久综合 | 国外av在线| 免费三级网| 狠狠色噜噜狠狠狠狠2021天天 | 久久精品视频3 | 久久久久久免费视频 | 99热精品在线观看 | 在线一二三区 | 欧美日本不卡 | 日本久久91| 日本三级吹潮在线 | 97色在线观看 | 欧美日韩高清一区二区 | 久久99久久99精品免费看小说 | 人人爽人人澡 | 一区二区中文字幕在线观看 | 精品99在线观看 | 91福利免费 | 波多野结衣电影一区 | 国产无限资源在线观看 | 亚洲精品1234区 | 亚洲欧美日韩在线一区二区 | 天天摸天天操天天舔 | 国产在线不卡一区 | 九九精品久久 | 久久成人精品电影 | 99精品国产成人一区二区 | 97超碰总站 | 欧美视频99| 久久久91精品国产一区二区精品 | 99精品国产视频 | 九九热视频在线播放 | 久久久在线免费观看 | 一级片免费在线 | 97香蕉超级碰碰久久免费软件 | 久久中文字幕在线视频 | av女优中文字幕在线观看 | 人人插人人 | 免费看三级网站 | 色搞搞 | 99久久精品国产亚洲 | 一区二区久久久久 | www.五月婷婷.com| 又大又硬又黄又爽视频在线观看 | 美女久久久久久久久久久 | 99国产在线视频 | 久久免费美女视频 | 99久久精品国产一区 | 美女又爽又黄 | 美女网站在线免费观看 | 涩五月婷婷 | av一本久道久久波多野结衣 | jizzjizzjizz亚洲| 国产色婷婷精品综合在线手机播放 | 美女久久久久久久久久久 | 免费精品在线视频 | 亚色视频在线观看 | 91高清免费在线观看 | 视频高清 | 激情五月婷婷综合 | 黄色网在线免费观看 | 国产四虎影院 | 国产一级免费视频 | av片一区二区 | 精品国产乱码一区二 | 黄色电影小说 | 国产亚洲精品久久久久久大师 | 91午夜精品 | wwwwww国产| 欧美黄在线 | 天天天天天天操 | 久久国产欧美日韩 | 国产香蕉视频在线播放 | 国产精品在线看 | 午夜精品区 | 在线视频中文字幕一区 | 国产精品久久久久久久久久久久久 | 日韩在线免费视频 | 又污又黄的网站 | 国产视频 亚洲视频 | 91精品国产入口 | 麻豆小视频在线观看 | 亚洲国产精品一区二区尤物区 | 久久久久一区二区三区 | av免费观看高清 | 在线观看网站你懂的 | 97精品欧美91久久久久久 | 亚洲我射av | 欧美另类性 | 麻豆视频在线播放 | 亚州国产精品视频 | 天堂在线v | 99re亚洲国产精品 | av网站在线免费观看 | 久久国产精品影片 | 国产一级高清视频 | 五月婷婷丁香综合 | 欧美日韩免费网站 | 91久久久久久国产精品 | 四虎影视4hu4虎成人 | 欧美日韩国产综合网 | 中文字幕在线播放一区二区 | 日日夜精品 | 中文字幕乱码一区二区 | 欧美日韩国产一区 | 97精品国产97久久久久久春色 | 免费看一及片 | 91视频在线免费 | 久久国产经典视频 | 欧美性色黄大片在线观看 | 精品一区久久 | 婷婷丁香激情网 | 国产精品国产三级在线专区 | 96av麻豆蜜桃一区二区 | 国产精品一二 | 人人爽人人澡人人添人人人人 | 蜜臀av性久久久久av蜜臀三区 | 午夜精品一区二区三区在线视频 | 夜夜爽夜夜操 | av片子在线观看 | 色999在线 | 99精品国产免费久久 | 91精品爽啪蜜夜国产在线播放 | 国产精品日韩精品 | 91在线91| 久久99久久99精品中文字幕 | 免费观看成人网 | 一区二区三区四区在线 | 久久爱资源网 | 免费看国产曰批40分钟 | 日韩久久久久久久 | 国产黄色免费看 | 日日夜日日干 | 亚洲永久av | 99久久精品国产毛片 | 久久久久久久久久久影视 | 久久五月天综合 | 国产在线观看xxx | 婷婷在线视频观看 | 国产精品 9999 | 免费黄色av. | 91精品秘密在线观看 | 国产视频欧美视频 | 久久99精品久久久久久秒播蜜臀 | 日本精品一区二区三区在线播放视频 | 国产手机在线观看 | 中文字幕在线观看不卡 | 婷婷色综合 | 国产免费观看视频 | 五月天激情综合 | 97免费 | 色天天综合网 | 探花视频在线版播放免费观看 | 日韩,精品电影 | av女优中文字幕在线观看 | 精品一二三四在线 | 成年人视频在线免费播放 | 九九热av| 久久久人人爽 | 欧美日韩另类视频 | 麻豆系列在线观看 | 中文在线免费视频 | 美女网站免费福利视频 | 中文字幕中文字幕在线中文字幕三区 | 国内精品久久久久 | 国产成人一区二区三区在线观看 | 国产精品久久久久av免费 | 综合色婷婷 | 亚洲在线观看av | 国产精品福利在线 | 国产美女在线观看 | 丁香婷婷亚洲 | bbb搡bbb爽爽爽 | 欧美韩国日本在线 | 欧美大片在线看免费观看 | 国产精品福利久久久 | 成人久久国产 | 国产成人av网 | 最新一区二区三区 | 亚洲成av人电影 | 国产在线观 | 黄色软件在线观看免费 | 精品国产成人在线影院 | 人人干人人草 | 欧美成天堂网地址 | av免费在线播放 | 中文字幕精品www乱入免费视频 | 国产日本三级 | 免费男女网站 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 国产精品手机播放 | 嫩嫩影院理论片 | 成人av手机在线 | 日韩理论片 | 久久这里只有精品1 | 色狠狠狠 | 国产亚洲一级高清 | 成人福利在线 | 麻豆综合网 | 日日干av | 精品亚洲午夜久久久久91 | 8x成人免费视频 | 六月激情网 | 黄色大全免费网站 | 97夜夜澡人人爽人人免费 | av福利电影 | 久久久亚洲麻豆日韩精品一区三区 | 超碰97在线人人 | 免费a网址 | 天天在线免费视频 | 黄色一区二区在线观看 | 成人一级在线 | 欧美一级片在线观看视频 | 在线视频欧美日韩 | 日日碰狠狠添天天爽超碰97久久 | 亚洲精品国内 | 97人人艹 | 天天插综合网 | 婷婷五月色综合 | 国产精品欧美日韩 | 亚洲激情在线播放 | 一区二区毛片 | 国产视频黄 | 久久夜色精品国产欧美一区麻豆 | 91精品一区国产高清在线gif | 国产五码一区 | 国产手机视频在线观看 | 国产精品18久久久久久vr | 国产精品国产自产拍高清av | 亚洲欧美在线视频免费 | 91丨九色丨国产在线观看 | 久久99亚洲精品久久 | 精品国产一区二区三区男人吃奶 | 国产五月| 亚洲精品视频在线观看免费视频 | 日韩av电影网站在线观看 | 色婷婷在线观看视频 | 国产免费xvideos视频入口 | 国产精品九九热 | 成在线播放| 久久国产乱 | 91福利在线导航 | 午夜a区| 91成人观看 | 色视频在线免费观看 | 成年人免费看av | 成人av动漫在线 | 日韩美一区二区三区 | 99国产在线 | 久久成人麻豆午夜电影 | av在线成人| 国产精品美女久久久久久 | av黄色免费看 | 337p西西人体大胆瓣开下部 | 一级黄色在线免费观看 | 奇米影视777四色米奇影院 | 99性视频 | 黄色电影在线免费观看 | 亚洲男人天堂a | 日韩理论片在线 | 免费看毛片在线 | 久久精品人 | 久久国产成人午夜av影院潦草 | 国产精品毛片一区二区三区 | 中文字幕日韩免费视频 | 久久久久久久久爱 | 亚洲理论片 | 日韩精品中文字幕在线播放 | 国产高清视频 | 深爱五月激情五月 | 天天爽人人爽夜夜爽 | 婷婷视频在线观看 | 国产91精品一区二区麻豆亚洲 | 色天天天 | 99精品网站 | 欧美成人亚洲成人 | 久久精品99久久久久久2456 | 人人精品久久 | 91成人看片 | 免费亚洲视频在线观看 | 在线国产能看的 | 密桃av在线 | av丝袜天堂 | 不卡av免费在线观看 | 中文字幕不卡在线88 | 久久精品电影 | 一区二区中文字幕在线观看 | 超碰人人91| 人人澡人| 91成人破解版 | 在线 影视 一区 | 亚洲成人午夜av | 美女国产 | 操操操干干干 | 日韩精品一区二区三区视频播放 | 丝袜+亚洲+另类+欧美+变态 | 不卡的av在线播放 | 91网址在线看 | 亚洲成人av电影在线 | 中文字幕有码在线 | 天堂网在线视频 | 国产日韩精品在线观看 | 国产高清视频在线播放 | 国产青草视频在线观看 | 成人av一区二区兰花在线播放 | 亚洲免费视频在线观看 | 国产精品成人aaaaa网站 | 91看成人 | 国产一区国产二区在线观看 | 国产品久精国精产拍 | 色91在线 | 欧美美女视频在线观看 | 亚洲经典在线 | 99精品视频播放 | av成人免费网站 | 麻花传媒mv免费观看 | 日韩最新在线 | 国产精品欧美激情在线观看 | 91香蕉嫩草| av福利在线免费观看 | 69久久久| 九九日九九操 | 免费91在线 | 久一久久| 亚洲精品视频免费看 | 黄色大片网 | 综合久久2023 | 欧美日韩大片在线观看 | 国产精品久久久久久久久蜜臀 | 国产精品专区h在线观看 | 亚洲三级黄 | 91免费国产在线观看 | 丝袜美腿亚洲 | 国产精品久久久久久久久岛 | 免费看毛片在线 | 精品国产一区二区三区四 | 91精品看片 | 亚州国产精品视频 | 欧美了一区在线观看 | 国产盗摄精品一区二区 | 国产96视频| 国产精品永久久久久久久www | 欧美日韩亚洲在线观看 | 亚洲精品女人久久久 | 亚洲精品一区二区网址 | 精品久久久免费视频 | 日韩免费电影网站 | 免费高清在线观看成人 | 婷婷视频在线观看 | 亚洲国产综合在线 | 97视频资源 | 成人av网站在线观看 | 国产一区私人高清影院 | 国产精品区二区三区日本 | 欧美在线视频a | 狠狠干狠狠色 | 欧美成人理伦片 | 一区二区三区在线免费播放 | 免费观看成年人视频 | 国产精品久久久久久久免费大片 | 久久久久久久av麻豆果冻 | 超碰在线97观看 | 在线观看一二三区 | 中文字幕免费高清在线 | 国产成人精品久久久 | 久久观看最新视频 | 久99久在线视频 | 精品国内自产拍在线观看视频 | 在线观看日韩中文字幕 | 国产黄色免费 | 91精品国产91热久久久做人人 | 免费在线观看av电影 | 中文在线字幕免费观 | 色婷婷亚洲 | 久久男人影院 | 91精品国产综合久久福利 | 色香天天 | 国产精品精品国产色婷婷 | av片中文字幕 | 国产成人av在线影院 | 久草在线视频看看 | 中文字幕在线视频一区二区 | 成人av中文字幕在线观看 | 香蕉视频国产在线观看 | 国产亚洲精品综合一区91 | 911在线 | 激情av在线资源 | 国产精品爽爽爽 | 99国产情侣在线播放 | 久久精品一区二区三区国产主播 | 日韩久久精品一区二区三区 | 久久久国产精品亚洲一区 | 国产99久久久欧美黑人 | 国产成人一区二区在线观看 | 久久 一区 | 国产 一区二区三区 在线 | 国产精在线 | 黄色a视频| 亚洲综合五月 | 日韩视频中文字幕在线观看 | 97伊人网| 国产中文在线观看 | 精品视频免费观看 | 午夜视频99| 亚洲视频久久久久 | 天天爽人人爽夜夜爽 | 免费国产一区二区视频 | 天堂网一区二区三区 | 亚洲黄色小说网 | 国产亚洲久一区二区 | 69欧美视频| 亚洲欧美日韩中文在线 | 欧美成人高清 | 国产精品成人一区 | 亚洲精品高清在线观看 | 欧美日韩高清一区二区 国产亚洲免费看 | 欧美久久久影院 | 97色在线| 欧美少妇的秘密 | 月下香电影 | 久久精品电影院 | 国产成人免费高清 | 天天综合网在线 | 伊人看片| 国产精品免费看久久久8精臀av | 亚洲综合网站在线观看 | 日本特黄特色aaa大片免费 | va视频在线 | 粉嫩一二三区 | 黄色软件网站在线观看 | 成人黄性视频 | 国产视频精选 | 久久久久久久久网站 | 亚洲精品国内 | 日韩欧美精品在线 | 国产爽视频| 国产我不卡 | 黄色小网站在线观看 | 99久热在线精品视频成人一区 | 狠狠色综合网站久久久久久久 | 91免费版在线观看 | 亚洲aⅴ免费在线观看 | 久久精品欧美一区 | 久久久久成人精品亚洲国产 | 久草网在线观看 | 国产精品网在线观看 | 久久久av免费 | 97视频在线免费 | 成片免费 | 日本一区二区三区视频在线播放 | 婷婷丁香激情五月 | 日韩欧美亚洲 | 免费看黄20分钟 | 日韩一区二区三区不卡 | 最新国产中文字幕 | 中文字幕乱在线伦视频中文字幕乱码在线 | 国产视频1区2区3区 久久夜视频 | 69国产精品视频免费观看 | 久久人人爽人人爽人人片av免费 | 日韩免费高清在线 | 欧美国产一区在线 | 91视频麻豆视频 | 欧美一区二区三区在线看 | 色射色 | 91在线观看欧美日韩 | 在线91色 | 日韩免费在线一区 | 国产黄色精品 | 久久久久久蜜桃一区二区 | 96精品在线 | 国产另类av | 午夜精品久久久久久久99无限制 | 国产亚洲精品久久久久动 | 国产流白浆高潮在线观看 | 欧美孕妇与黑人孕交 | 久久视频一区二区 | 久久国产香蕉视频 | 久久久久国产精品厨房 | 九九九九热精品免费视频点播观看 | 精品在线观看一区二区 | 日韩理论片在线 | 精品免费久久久久 | 成人精品视频 | 美女视频国产 | 久久久久综合 | 亚洲精品视频中文字幕 | 午夜精品一区二区三区视频免费看 | 五月婷婷在线视频观看 | 亚洲理论电影 | 久久伊99综合婷婷久久伊 | 成人在线你懂得 | 超碰在线人人爱 | 激情婷婷色 | 日韩欧美高清视频在线观看 | 91桃色免费观看 | 国产精品成人在线 | 91在线观看视频 | 日韩中出在线 | 在线观看电影av | 精品美女国产在线 | www国产亚洲精品久久麻豆 | 久久久久久久国产精品影院 | 在线免费视频一区 | 开心激情综合网 | 国产人在线成免费视频 | 日韩黄在线观看 | 狠狠色丁香婷婷综合 | 激情欧美网 | 一区二区三区四区五区在线 | 婷婷久草| 日日日爽爽爽 | av在线播放观看 | 国产九色91 | 黄色免费网站下载 | 一区二区精品久久 | 亚洲理论在线观看 | 狠狠色丁香久久婷婷综合五月 | 在线视频观看成人 | 色a综合 | 亚洲一区二区天堂 | 亚洲一区网 | 日韩网页 | 免费高清无人区完整版 | 久久国产亚洲视频 | 国产v在线观看 | 手机av看片| 日韩精品中文字幕在线播放 | 在线观看一二三区 | 亚洲日本va在线观看 | 久香蕉 | 奇米影视777影音先锋 | 日韩影视大全 | 亚洲精欧美一区二区精品 | 韩国一区在线 | 综合网伊人 | 婷婷丁香色 | 91新人在线观看 | 91精品久久久久久久久久久久久 | 久久免费看视频 | 91成人免费在线 | 激情欧美一区二区免费视频 | 婷婷激情综合五月天 | 狠狠ri| 人人干狠狠干 | 亚洲不卡123 | 成人av一区二区在线观看 | 国产尤物在线视频 | 高清有码中文字幕 | 中文字幕 91 | 97**国产露脸精品国产 | 国产成人99av超碰超爽 | 色婷在线 | 色婷婷色 | 久久综合婷婷 | 六月色丁 | 91网站在线视频 | 久草热久草视频 | 久久综合中文色婷婷 | 在线电影中文字幕 | 91精品视频导航 | 国产91在线观看 | 久久人人爽爽人人爽人人片av | 国产无遮挡又黄又爽馒头漫画 | 国产一区二区在线精品 | 天天干天天操 | av线上免费看 | 日本精品中文字幕在线观看 | 欧美日韩免费观看一区=区三区 | 97超碰中文| 日韩免费视频一区二区 | 国产手机视频在线播放 | 麻豆视频观看 | 免费观看黄 | 91av中文| 国产精选视频 | 日本黄色免费电影网站 | 黄色在线成人 | 久热免费在线 | 日韩精品欧美专区 | 色婷婷中文 | 国产第一页在线播放 | 探花视频在线版播放免费观看 | 天天干天天爽 | 久草视频免费在线观看 | 黄色片亚洲 | 欧美亚洲精品在线观看 | 日韩精品一区二区三区高清免费 | 97偷拍在线视频 | 国产成人三级一区二区在线观看一 | 午夜精选视频 | 精品国产一区二区三区四区在线观看 | 亚洲h视频在线 | 国内精品久久久久影院男同志 | 国产成人av一区二区三区在线观看 | 激情丁香久久 | 日日干美女 | 日韩精品资源 | 国产在线观看午夜 | 日韩com| 激情久久小说 | 91精品欧美一区二区三区 | 尤物九九久久国产精品的分类 | 欧美日韩一区二区三区视频 | 国产网站av | 成人免费网站视频 | zzijzzij日本成熟少妇 | 伊人色综合久久天天 | 天天爽天天做 | 国产午夜在线观看 | 久久久久久久久国产 | 欧美日韩不卡在线视频 | 久久久久国产精品免费免费搜索 | 在线三级中文 | 国产区精品视频 | 国产成人一区二区精品非洲 | 精品国产一区二区三区久久影院 | 久久你懂得 | 精品久久五月天 | 久久成人亚洲欧美电影 | 一区二区三区视频网站 | 狠狠色噜噜狠狠狠狠 | 在线视频观看你懂的 | 婷婷av综合 | 亚洲精品美女久久 | sm免费xx网站 | www.天天射 | 日日夜夜天天射 | 一区二区视频欧美 | 黄色网址中文字幕 | 国产美女视频网站 | 国产成人一区二区三区免费看 | 免费看91的网站 | 国内视频 | 国产vs久久 | 天天干天天做 | 日韩中文字幕一区 | 在线播放视频一区 | 久久精视频 | 99久久精品国产一区二区成人 | 97超级碰碰碰视频在线观看 | 九九热在线视频 | 午夜美女福利直播 | 亚洲天堂在线观看完整版 | 在线日韩中文字幕 | 特级免费毛片 | 国产精品一区二区麻豆 | 综合网天天色 | 日本性动态图 | 久久y| 国产黄在线免费观看 | 日韩二区在线 | 久久伊人免费视频 | 中文字幕国产在线 | 国产手机在线播放 | 伊人婷婷综合 | 国产成人一区二 | 中文字幕在线视频网站 | 狠狠色丁香九九婷婷综合五月 | 久久一区二区三区国产精品 | 精品国产伦一区二区三区 | av一级网站 | 成人a在线观看高清电影 | 日韩网站免费观看 | 99久热在线精品 | 亚洲精品小区久久久久久 | 日韩欧美高清一区二区三区 | 日韩精品一区二区三区高清免费 | 成年人在线观看视频免费 | 日本女人b | 深爱五月网 | 欧美做受高潮1 | 亚洲精品国偷拍自产在线观看蜜桃 | 欧美成人免费在线 | 外国av网 | 亚洲人在线7777777精品 | 国产一级做a爱片久久毛片a | 国产精品久久久久久久久久99 | 欧美日韩伦理在线 | 青青河边草手机免费 | 激情www | 色综合天天狠天天透天天伊人 | 成人禁用看黄a在线 | 麻豆网站免费观看 | 亚洲做受高潮欧美裸体 | 免费热情视频 | 国产精品久久久久久久妇 | 日韩欧美xxxx | 亚洲丝袜一区二区 | 亚洲成人av一区 | 波多野结衣一区三区 | 91精品视频免费在线观看 | 久久久精品国产免费观看一区二区 | 黄色片网站大全 | 日本深夜福利视频 | 夜夜夜| 亚洲精品麻豆视频 | 成人av电影在线播放 | 在线观看一区二区视频 | 中文有码在线 | 黄色影院在线免费观看 | 成年免费在线视频 | 免费在线成人av电影 | 91九色国产 | 天堂在线一区二区 | 精品综合久久 | 国产美女被啪进深处喷白浆视频 | 天天爱天天草 | 狠狠狠狠狠狠狠狠干 | 丰满少妇在线观看网站 | 亚洲一区二区三区精品在线观看 | 日本精品久久久久影院 | 免费黄色在线播放 | 色综合天天色综合 | 激情久久伊人 | 91av在线视频免费观看 | 天天干天天做 | 91网页版免费观看 | 我爱av激情网 | 人人干天天干 | 国产成人精品一区二区在线观看 | av天天干| 久久久精品国产一区二区 | 日韩欧美一区二区三区黑寡妇 | 国产成人一区二区在线观看 | 亚洲夜夜综合 | 色婷婷综合久久久久中文字幕1 | 在线视频 国产 日韩 | 国产黄色免费看 | 国产精品成人久久久久 | 日韩在线高清免费视频 | 在线免费观看涩涩 | 91精品啪在线观看国产81旧版 | 激情五月av| 九九视频在线 | 欧美性黑人| 中文字幕乱码亚洲精品一区 | 97色噜噜 | www.97视频 | 香蕉在线观看视频 | 久久美女电影 | 国产精品69av | 亚洲国产一区在线观看 | 免费成人av在线看 | av网址在线播放 | 五月婷婷狠狠 | 91看毛片| 在线观看韩日电影免费 | 91黄色在线观看 | 日韩一区二区在线免费观看 | 五月婷网站 | 久久国产精品色婷婷 | 国产免费人成xvideos视频 | 91丨九色丨勾搭 | 特级免费毛片 | 精品一区二区久久久久久久网站 | 中文理论片 | www.婷婷com | 中文字幕免费不卡视频 | 超碰电影在线观看 | www.97视频| 精品网站999www | 一区二区久久 | 亚洲综合日韩在线 | 91亚洲网站| 24小时日本在线www免费的 | 天天天射 | 欧美福利精品 | 久久亚洲日本 | 国产日韩在线一区 | 国产手机在线视频 | 成人在线一区二区三区 | 欧美另类色图 | 99精品黄色 | 欧美性色19p| 欧美日韩精品免费观看视频 | 亚洲黄色一级大片 | 香蕉在线观看视频 | 国产精品成人自产拍在线观看 | 国产精品美女www爽爽爽视频 | 99精品国产视频 | 久久亚洲综合色 | 国产在线观看不卡 | 国产欧美三级 | 婷婷色中文字幕 | 在线观看视频精品 | 高清不卡免费视频 | 99久久久国产精品免费99 | 91在线视频 | 美腿丝袜av | 久久视频在线观看 | 成年人电影免费看 | 国产热re99久久6国产精品 | 精品国产精品久久一区免费式 | 91视频成人免费 | 国产精品激情偷乱一区二区∴ | 欧美专区日韩专区 | 手机看片1042| 日韩一区二区三免费高清在线观看 | 美女黄频免费 | www日韩视频| av高清在线观看 | 五月天久久狠狠 | 日本中文字幕视频 | 欧美性色黄大片在线观看 | 免费视频区 | 国产在线视频一区二区三区 | 夜夜天天干| 超碰97网站| 亚洲情婷婷 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 91色九色 | 精品uu| 国产福利一区二区三区在线观看 | 三级性生活视频 | 日韩精品久久久久久中文字幕8 | 国产小视频你懂的 | 欧美日韩性| 三级性生活视频 | 中国一级片免费看 | 五月婷婷色综合 | 亚洲精品美女在线观看 | 欧美日韩在线视频一区 | 久久一区二区三区超碰国产精品 | av电影中文字幕 | 狠狠狠操| 伊人天天综合 | 亚洲国产高清视频 | 日韩欧美aaa| 久久伊人精品一区二区三区 | 亚洲码国产日韩欧美高潮在线播放 | 国产精品video | 亚洲综合激情五月 | 久久国产精品视频 | 色婷婷视频在线观看 | 国产精品麻豆一区二区三区 | 久久久久久久久久亚洲精品 | 久久a级片 | 在线观看黄网站 | 96av视频| 亚洲黄色av| 欧美一级高清片 | 色狠狠操 | 亚洲黄色在线播放 |