3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

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

编程问答

Leetcode-一篇帖子就够啦

發布時間:2025/4/5 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Leetcode-一篇帖子就够啦 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

# 注:下面按照算法類別由淺入深,把下面羅列的這些題刷完,并且多看這些題不同的解法(國際版mostvotes),看懂之后估計就不會有太大的問題啦~

整體框架

數據結構: 一維:基礎: 數組array(string),鏈表linked list高級 : 棧stack,隊列queue,雙端隊列deque,集合set,映射 map(hash or map), etc二維:基礎:樹tree,圖graph高級: 二叉搜索樹binary search tree(red-black tree,AVL),堆heap,并查集disjoint set,字典樹Trie特殊:位運算Bitwise,布隆過濾器BloomFilterLRU Cache算法:遞歸Recursion搜索Search: 深度優先搜索Depth first search,廣度優先搜索Breadth first search動態規劃 Dynamic Programming二分查找 Binary Search貪心 Greedy

數組&鏈表部分

一、數組部分

數組的常見寫法: Java,C++: int a[50] ;? Python: list = []??

注:高級數據語言可以不指定類型語言

數組底層硬件實現,有一個內存管理器,每當申請一個數組時,計算機會在內存中開辟一段連續的地址,每一個地址都可以直接通過內存管理器直接訪問,訪問任意一個位置,時間復雜度都是一致的都是O(1)

數組的插入和刪除都需要O(n)的時間復雜度

看一下Java源碼,數組插入和刪除的操作過程:

http://developer.classpath.org/doc/java/util/ArrayList-source.html329: /**330: * Appends the supplied element to the end of this list.331: * The element, e, can be an object of any type or null.332: *333: * @param e the element to be appended to this list334: * @return true, the add will always succeed335: */336: public boolean add(E e)337: {338: modCount++;339: if (size == data.length)340: ensureCapacity(size + 1);341: data[size++] = e;342: return true;343: }數組添加一個元素e,modCount是一個計數器,ensureCapacity保證數組的容量,末尾插入一個元素e345: /**346: * Adds the supplied element at the specified index, shifting all347: * elements currently at that index or higher one to the right.348: * The element, e, can be an object of any type or null.349: *350: * @param index the index at which the element is being added351: * @param e the item being added352: * @throws IndexOutOfBoundsException if index &lt; 0 || index &gt; size()353: */354: public void add(int index, E e)355: {356: checkBoundInclusive(index);357: modCount++;358: if (size == data.length)359: ensureCapacity(size + 1);360: if (index != size)361: System.arraycopy(data, index, data, index + 1, size - index);362: data[index] = e;363: size++;364: }指定位置index處插入元素e, checkBoundInclusive-檢查是都越界,ensureCapacity保證數組容量,arraycopy-對數組序列進行移動463: /**464: * Checks that the index is in the range of possible elements (inclusive).465: *466: * @param index the index to check467: * @throws IndexOutOfBoundsException if index &gt; size468: */469: private void checkBoundInclusive(int index)470: {471: // Implementation note: we do not check for negative ranges here, since472: // use of a negative index will cause an ArrayIndexOutOfBoundsException,473: // a subclass of the required exception, with no effort on our part.474: if (index > size)475: throw new IndexOutOfBoundsException("Index: " + index + ", Size: "476: + size);477: }checkBoundInclusive檢查是否越界160: /**161: * Guarantees that this list will have at least enough capacity to162: * hold minCapacity elements. This implementation will grow the list to163: * max(current * 2, minCapacity) if (minCapacity &gt; current). The JCL says164: * explictly that "this method increases its capacity to minCap", while165: * the JDK 1.3 online docs specify that the list will grow to at least the166: * size specified.167: *168: * @param minCapacity the minimum guaranteed capacity169: */170: public void ensureCapacity(int minCapacity)171: {172: int current = data.length;173: 174: if (minCapacity > current)175: {176: E[] newData = (E[]) new Object[Math.max(current * 2, minCapacity)];177: System.arraycopy(data, 0, newData, 0, size);178: data = newData;179: }180: }ensureCapacity-確保數組的容量數組的刪除操作和插入操作同理,也會用到相應的函數366: /**367: * Removes the element at the user-supplied index.368: *369: * @param index the index of the element to be removed370: * @return the removed Object371: * @throws IndexOutOfBoundsException if index &lt; 0 || index &gt;= size()372: */373: public E remove(int index)374: {375: checkBoundExclusive(index);376: E r = data[index];377: modCount++;378: if (index != --size)379: System.arraycopy(data, index + 1, data, index, size - index);380: // Aid for garbage collection by releasing this pointer.381: data[size] = null;382: return r;383: } 二、鏈表部分(Linked List) 鏈表部分彌補前面數組部分的缺點(插入和刪除時間復雜度過高)每一個元素都需要定義一個class,頭指針用head表示,尾指針用tail表示,最后一個元素next指針指向空,因為沒有next指針啦;如果tail 的next指針指向head時,為循環鏈表 Java-Linked List源碼: http://developer.classpath.org/doc/java/util/LinkedList-source.html 鏈表的插入和刪除操作沒有引起鏈表的群移操作,也不需要復制元素 操作 時間復雜度(linkedList vs Array) prepend(前向插入) O(1) vs O(1) append(后向插入) O(1) vs O(1) lookup(查詢) O(n) vs O(1) insert(插入) O(1) vs O(n) delete(刪除) O(1) vs O(n) 從圖中可以看出,查詢操作時間復雜度為O(n),也是鏈表的問題所在,所以可以看出并沒有一種完美的數據結構,根據不同的需求用相應的數據結構即可三、跳表常見于redis中,鏈表的缺點在于查詢時間復雜度為O(n),對鏈表查詢進行加速,中心思想-空間換時間原始鏈表-時間復雜度:O(n) 簡單優化:添加頭尾指針 ,多添加指針會更快一級索引加速,速度可以加快,還可以增加第二級索引,更快加快速度,通常增加log2n級索引,跳表時間復雜度為logn。例如一個鏈表原始長度為1024,按照原始查詢方式需要查1024次,如果按照跳表進行查詢,只需要查詢10次。增加和刪除操作,跳表需要更新一次。跳表的時間復雜度為O(logn),空間復雜度為O(n)。redis應用跳表參考鏈接:https://redisbook.readthedocs.io/en/latest/internal- datastruct/skiplist.html四、實戰題目題目1:Leetcode-283-移動零給定一個數組 nums,編寫一個函數將所有 0 移動到數組的末尾, 同時保持非零元素的相對順序。示例:輸入: [0,1,0,3,12] 輸出: [1,3,12,0,0] 說明:必須在原數組上操作,不能拷貝額外的數組。 盡量減少操作次數。解法一:雙指針從前到后進行遍歷,遇到不是0的元素往前移,0元素放在后面class Solution:def moveZeroes(self, nums: List[int]) -> None:"""Do not return anything, modify nums in-place instead."""j = 0for i in range(len(nums)):if nums[i]!=0:nums[j] = nums[i]if i!=j:nums[i] = 0j += 1效率: 提交時間 提交結果 執行用時 內存消耗 語言 幾秒前 通過 52 ms 14.5 MB Python3解法二:遍歷數組,構建一個索引,遇到不是零的元素,則添加到數組前面, 直到遍歷完數組,index-至數組末尾添加0 class Solution:def moveZeroes(self, nums: List[int]) -> None:"""Do not return anything, modify nums in-place instead."""index = 0for i in range(len(nums)):if nums[i]!=0:nums[index] = nums[i]index +=1for i in range(index,len(nums)):nums[i] = 0性能: 提交時間 提交結果 執行用時 內存消耗 語言 幾秒前 通過 88 ms 14.4 MB Python3Most votes: // Shift non-zero values as far forward as possible // Fill remaining space with zerospublic void moveZeroes(int[] nums) {if (nums == null || nums.length == 0) return;int insertPos = 0;for (int num: nums) {if (num != 0) nums[insertPos++] = num;}while (insertPos < nums.length) {nums[insertPos++] = 0;} }# in-place def moveZeroes(self, nums):zero = 0 # records the position of "0"for i in xrange(len(nums)):if nums[i] != 0:nums[i], nums[zero] = nums[zero], nums[i]zero += 1題目2Leetcode-11-盛最多水的容器給定 n 個非負整數 a1,a2,...,an,每個數代表坐標中的一個點 (i, ai) 。 在坐標內畫 n 條垂直線,垂直線 i 的兩個端點分別為 (i, ai) 和 (i, 0)。 找出其中的兩條線,使得它們與 x 軸共同構成的容器可以容納最多的水。 說明:你不能傾斜容器,且 n 的值至少為 2。圖中垂直線代表輸入數組 [1,8,6,2,5,4,8,3,7]。在此情況下, 容器能夠容納水(表示為藍色部分)的最大值為 49。 示例: 輸入: [1,8,6,2,5,4,8,3,7] 輸出: 49解法一、暴力解法: class Solution:def maxArea(self, height: List[int]) -> int:max_area = 0for i in range(len(height)):for j in range(i+1,len(height)):max_area = max(max_area,min(height[j],height[i])*(j-i))return max_area性能:超時解法二、雙指針 數組左側一個指針,右側一個指針,兩個指針向中間移動,直到兩者相遇; 算指針高度較小的指針的高度,指針移動。 class Solution:def maxArea(self, height: List[int]) -> int:i,j,max_area = 0,len(height)-1,0while i<j:if height[i] < height[j]:max_area = max(max_area,height[i]*(j-i))i += 1else:max_area = max(max_area,height[j]*(j-i))j -= 1return max_area提交時間 提交結果 執行用時 內存消耗 語言 幾秒前 通過 232 ms 14.7 MB Python3MostVotes: class Solution(object):def maxArea(self, height):""":type height: List[int]:rtype: int"""MAX = 0 x = len(height) - 1y = 0while x != y:if height[x] > height[y]:area = height[y] * (x - y)y += 1else:area = height[x] * (x - y)x -= 1MAX = max(MAX, area)return MAXint maxArea(vector<int>& height) {int water = 0;int i = 0, j = height.size() - 1;while (i < j) {int h = min(height[i], height[j]);water = max(water, (j - i) * h);while (height[i] <= h && i < j) i++;while (height[j] <= h && i < j) j--;}return water; }題目3Leetcode-70-爬樓梯假設你正在爬樓梯。需要 n 階你才能到達樓頂。 每次你可以爬 1 或 2 個臺階。你有多少種不同的方法可以爬到樓頂呢? 注意:給定 n 是一個正整數。示例 1: 輸入:2 輸出:2 解釋:有兩種方法可以爬到樓頂。 1. 1 階 + 1 階 2. 2 階 # 解法 class Solution:# 只保存最近的三個值def climbStairs(self, n: int) -> int:if n<=2:return nelse:f1,f2,f3 = 1,2,3for i in range(3,n+1):f3 = f1 + f2f1 = f2f2 = f3return f3時間復雜度O(n),空間復雜度為O(1)Time Submitted Status Runtime Memory Language 28 minutes ago Accepted 104 ms 13 MB python 官方給出兩個比較新穎的解法:Binets方法 && 斐波那契公式,詳見 https://leetcode-cn.com/problems/climbing-stairs/solution /pa-lou-ti-by-leetcode/ 題目4Leetcode-15-三數之和精選題解(https://leetcode-cn.com/problems/3sum/solution/pai-xu-shuang-zhi-zhen-zhu-xing-jie-shi-python3-by/):排序 + 雙指針 本題的難點在于如何去除重復解。算法流程: 特判,對于數組長度 nn,如果數組為 nullnull 或者數組長度小于 3,返回 []。 對數組進行排序。 遍歷排序后數組: 若 nums[i]>0nums[i]>0:因為已經排序好,所以后面不可能有三個數加和等于 0,直接返回結果。 對于重復元素:跳過,避免出現重復解 令左指針 L=i+1,右指針 R=n-1,當 L<R時,執行循環: 當 nums[i]+nums[L]+nums[R]==0,執行循環,判斷左界和右界是否和下一位置重復,去除重復解。并同時將 L,R 移到下一位置,尋找新的解 若和大于 0,說明 nums[R]太大,RR 左移 若和小于 0,說明 nums[L]太小,LL 右移 復雜度分析 時間復雜度:O(n^2),數組排序O(NlogN),遍歷數組O(N),雙指針遍歷O(n),總體O(NlogN)+O(n)+O(n)*O(n) => O(n^2) 空間復雜度: O(1)class Solution:def threeSum(self, nums: List[int]) -> List[List[int]]:n=len(nums)res=[]if(not nums or n<3):return []nums.sort()res=[]for i in range(n):if(nums[i]>0):return resif(i>0 and nums[i]==nums[i-1]):continueL=i+1R=n-1while(L<R):if(nums[i]+nums[L]+nums[R]==0):res.append([nums[i],nums[L],nums[R]])while(L<R and nums[L]==nums[L+1]):L=L+1while(L<R and nums[R]==nums[R-1]):R=R-1L=L+1R=R-1elif(nums[i]+nums[L]+nums[R]>0):R=R-1else:L=L+1return res提交時間 提交結果 執行用時 內存消耗 語言 幾秒前 通過 1508 ms 16.6 MB Python3題目5Leetcode-206-反轉鏈表反轉一個單鏈表。示例:輸入: 1->2->3->4->5->NULL 輸出: 5->4->3->2->1->NULL 進階: 你可以迭代或遞歸地反轉鏈表。你能否用兩種方法解決這道題?解法一:雙指針迭代 思想,申請兩個指針,一個指針指向空,一個指針指向頭結點,然后遍歷鏈表,每個元素指向空指針方向 class Solution:def reverseList(self, head: ListNode) -> ListNode:pre = Nonecur = headwhile cur:item = cur.nextcur.next = prepre = curcur = itemreturn pre時間復雜度為O(n),空間復雜度為O(1) 提交時間 提交結果 執行用時 內存消耗 語言 幾秒前 通過 36 ms 14.2 MB Python3遞歸-精選題解(https://leetcode-cn.com/problems/reverse-linked-list/solution/dong-hua-yan-shi-206-fan-zhuan-lian-biao-by-user74/) class Solution(object):def reverseList(self, head):""":type head: ListNode:rtype: ListNode"""# 遞歸終止條件是當前為空,或者下一個節點為空if(head==None or head.next==None):return head# 這里的cur就是最后一個節點cur = self.reverseList(head.next)# 這里請配合動畫演示理解# 如果鏈表是 1->2->3->4->5,那么此時的cur就是5# 而head是4,head的下一個是5,下下一個是空# 所以head.next.next 就是5->4head.next.next = head# 防止鏈表循環,需要將head.next設置為空head.next = None# 每層遞歸函數都返回cur,也就是最后一個節點return cur題目6Leetcode-24-兩兩交換鏈表中的節點給定一個鏈表,兩兩交換其中相鄰的節點,并返回交換后的鏈表。 你不能只是單純的改變節點內部的值,而是需要實際的進行節點交換。示例: 給定 1->2->3->4, 你應該返回 2->1->4->3.class Solution:def swapPairs(self, head: ListNode) -> ListNode:if not head or not head.next:return headfirst_node = headsecond_node = head.nextfirst_node.next = self.swapPairs(second_node.next)second_node.next = first_nodereturn second_node 題目7Leetcode-141-環形鏈表給定一個鏈表,判斷鏈表中是否有環。為了表示給定鏈表中的環,我們使用整數 pos 來表示鏈表尾連接到鏈表中的位置(索引從 0 開始)。如果 pos 是 -1,則在該鏈表中沒有環。 解法一:ListNode放在集合里,遍歷列表,如果元素出現在集合里,則表示構成環 class Solution:def hasCycle(self, head: ListNode) -> bool:set_ = set()while head:if head in set_:return Trueset_.add(head)head = head.nextreturn False提交時間 提交結果 執行用時 內存消耗 語言 幾秒前 通過 48 ms 16.5 MB Python3解法二:快慢指針class Solution:def hasCycle(self, head: ListNode) -> bool:if not head or not head.next:return Falsei,j = head,head.nextwhile j and j.next:if i==j:return Truei,j = i.next,j.next.nextreturn False提交時間 提交結果 執行用時 內存消耗 語言 幾秒前 通過 76 ms 16.3 MB Python3 題目8Leetcode-142-環形鏈表 II給定一個鏈表,返回鏈表開始入環的第一個節點。 如果鏈表無環,則返回 null。 為了表示給定鏈表中的環,我們使用整數 pos 來表示鏈表尾連接到鏈表中的位置(索引從 0 開始)。如果 pos 是 -1,則在該鏈表中沒有環。class Solution:def detectCycle(self, head: ListNode) -> ListNode:se = set()node = headwhile node is not None:if node in se:return nodeelse:se.add(node)node = node.nextreturn node 提交時間 提交結果 執行用時 內存消耗 語言 幾秒前 通過 60 ms 16.8 MB Python3 題目9Leetcode-25-K 個一組翻轉鏈表給你一個鏈表,每 k 個節點一組進行翻轉,請你返回翻轉后的鏈表。 k 是一個正整數,它的值小于或等于鏈表的長度。 如果節點總數不是 k 的整數倍,那么請將最后剩余的節點保持原有順序。 示例 : 給定這個鏈表:1->2->3->4->5 當 k = 2 時,應當返回: 2->1->4->3->5 當 k = 3 時,應當返回: 3->2->1->4->5 說明 : 你的算法只能使用常數的額外空間。 你不能只是單純的改變節點內部的值,而是需要實際的進行節點交換 優選解法-參考https://leetcode-cn.com/problems/reverse-nodes-in-k-group/solution/kge-yi-zu-fan-zhuan-lian-biao-by-powcai/ 題目10Leetcode-26-刪除排序數組中的重復項給定一個排序數組,你需要在原地刪除重復出現的元素,使得每個元素只出現一次,返回移除后數組的新長度。 不要使用額外的數組空間,你必須在原地修改輸入數組并在使用 O(1) 額外空間的條件下完成。 示例 1: 給定數組 nums = [1,1,2], 函數應該返回新的長度 2, 并且原數組 nums 的前兩個元素被修改為 1, 2。 你不需要考慮數組中超出新長度后面的元素class Solution:def removeDuplicates(self, nums: List[int]) -> int:if len(nums) == 0:return 0i = 0for j in range(1,len(nums)):if nums[i]!=nums[j]:i +=1nums[i] = nums[j]return i + 1提交時間 提交結果 執行用時 內存消耗 語言 幾秒前 通過 88 ms 14.9 MB Python3 題目11Leetcode-189-旋轉數組給定一個數組,將數組中的元素向右移動 k 個位置,其中 k 是非負數。示例 1: 輸入: [1,2,3,4,5,6,7] 和 k = 3 輸出: [5,6,7,1,2,3,4] 解釋: 向右旋轉 1 步: [7,1,2,3,4,5,6] 向右旋轉 2 步: [6,7,1,2,3,4,5] 向右旋轉 3 步: [5,6,7,1,2,3,4]class Solution:def rotate(self, nums: List[int], k: int) -> None:"""Do not return anything, modify nums in-place instead."""n = len(nums)k %= nfor i in range(k):nums.insert(0,nums.pop()) 題目12Leetcode-21-合并兩個有序鏈表將兩個有序鏈表合并為一個新的有序鏈表并返回。新鏈表是通過拼接給定的兩個鏈表的所有節點組成的。 示例: 輸入:1->2->4, 1->3->4 輸出:1->1->2->3->4->4 class Solution:def mergeTwoLists(self, l1: ListNode, l2: ListNode) -> ListNode:if l1 is None:return l2elif l2 is None:return l1elif l1.val < l2.val:l1.next = self.mergeTwoLists(l1.next,l2)return l1else:l2.next = self.mergeTwoLists(l1,l2.next)return l2 題目13Leetcode-88-合并兩個有序數組給定兩個有序整數數組 nums1 和 nums2,將 nums2 合并到 nums1 中,使得 num1 成為一個有序數組。 說明: 初始化 nums1 和 nums2 的元素數量分別為 m 和 n。 你可以假設 nums1 有足夠的空間(空間大小大于或等于 m + n)來保存 nums2 中的元素。 示例: 輸入: nums1 = [1,2,3,0,0,0], m = 3 nums2 = [2,5,6], n = 3 輸出: [1,2,2,3,5,6]方法一: class Solution:def merge(self, nums1: List[int], m: int, nums2: List[int], n: int) -> None:"""Do not return anything, modify nums1 in-place instead."""nums1[:] = sorted(nums1[:m] + nums2[:n])時間復雜度O(n+m)log(n+m),空間復雜度O(1)方法二: class Solution:def merge(self, nums1: List[int], m: int, nums2: List[int], n: int) -> None:"""Do not return anything, modify nums1 in-place instead."""res = []p1,p2 = 0,0nums1[:] = nums1[:m]while p1 < m and p2 < n:if nums1[p1] < nums2[p2]:res.append(nums1[p1])p1 += 1else:res.append(nums2[p2])p2 += 1if p1 < m:res[p1+p2:] = nums1[p1:]if p2 < n:res[p1+p2:] = nums2[p2:]nums1[:] = res[:]時間復雜度O(n+m),空間復雜度O(m)方法三: class Solution:def merge(self, nums1: List[int], m: int, nums2: List[int], n: int) -> None:"""Do not return anything, modify nums1 in-place instead."""p1,p2,p = m-1,n-1,m+n-1while p1 >= 0 and p2 >= 0:if nums1[p1] < nums2[p2]:nums1[p] = nums2[p2]p2 -= 1else:nums1[p] = nums1[p1]p1 -= 1p -= 1nums1[:p2+1] = nums2[:p2+1] 時間復雜度O(m+n),空間復雜度O(1) 題目14Leetcode-1-兩數之和給定一個整數數組 nums 和一個目標值 target,請你在該數組中找出和為目標值的那 兩個 整數,并返回他們的數組下標。 你可以假設每種輸入只會對應一個答案。但是,你不能重復利用這個數組中同樣的元素。 示例: 給定 nums = [2, 7, 11, 15], target = 9 因為 nums[0] + nums[1] = 2 + 7 = 9 所以返回 [0, 1]class Solution:def twoSum(self, nums: List[int], target: int) -> List[int]:map_ = {}for idx,num in enumerate(nums):map_[num] = idxfor i,num in enumerate(nums):j = map_.get(target-num)if j is not None and i!=j:return [i,j] 題目15Leetcode-66-加一給定一個由整數組成的非空數組所表示的非負整數,在該數的基礎上加一。 最高位數字存放在數組的首位, 數組中每個元素只存儲單個數字。 你可以假設除了整數 0 之外,這個整數不會以零開頭。示例 1: 輸入: [1,2,3] 輸出: [1,2,4] 解釋: 輸入數組表示數字 123。 class Solution:def plusOne(self, digits: List[int]) -> List[int]:return list(map(int, list(str(int(''.join(map(str, digits))) + 1))))

棧、隊列部分

一、棧和隊列的優先特性

Stack & Queue 關鍵點

Stack: 先入后出:添加、刪除皆為O(1)

Queue: 先入先出:添加、刪除皆為O(1)

查詢為O(n),元素是無序的

雙端隊列(Deque):棧和隊列的結合體,可以從最前面或者最后面push或pop出來,插入和刪除是O(1),查詢是O(n)

Stack、Queue、Deque的工程實現

Java?Stack?源碼:http://developer.classpath.org/doc/java/util/Stack-source.htmlJava?Queue?源碼:http://fuseyism.com/classpath/doc/java/util/Queue-source.html 1、Leetcode-20-有效的符號給定一個只包括 '(',')','{','}','[',']' 的字符串,判斷字符串是否有效。 有效字符串需滿足: 左括號必須用相同類型的右括號閉合。 左括號必須以正確的順序閉合。 注意空字符串可被認為是有效字符串。class Solution:def isValid(self, s: str) -> bool:dic = {'(':')','{':'}','[':']','a':'a'}res = ['a']if len(s) == 0:return Trueif len(s)%2==1:return Falsefor ch in s:if ch in dic:res.append(ch)elif dic[res.pop()]!=ch:return Falsereturn len(res)==1提交時間 提交結果 執行用時 內存消耗 語言 幾秒前 通過 20 ms 13.2 MB Python3Mostvotes class Solution:# @return a booleandef isValid(self, s):stack = []dict = {"]":"[", "}":"{", ")":"("}for char in s:if char in dict.values():stack.append(char)elif char in dict.keys():if stack == [] or dict[char] != stack.pop():return Falseelse:return Falsereturn stack == []2、Leetcode-155-最小棧設計一個支持 push,pop,top 操作,并能在常數時間內檢索到最小元素的棧。push(x) -- 將元素 x 推入棧中。 pop() -- 刪除棧頂的元素。 top() -- 獲取棧頂元素。 getMin() -- 檢索棧中的最小元素 class MinStack:def __init__(self):"""initialize your data structure here."""self.stack_1,self.stack_2 = [],[]def push(self, x: int) -> None:self.stack_1.append(x)if len(self.stack_2) ==0 or x<= self.stack_2[-1]:self.stack_2.append(x)else:self.stack_2.append(self.stack_2[-1])def pop(self) -> None:if self.stack_1:self.stack_2.pop()return self.stack_1.pop()def top(self) -> int:if self.stack_1:return self.stack_1[-1]def getMin(self) -> int:if self.stack_2:return self.stack_2[-1]3、Leetcode-84-柱狀圖中最大的矩形給定 n 個非負整數,用來表示柱狀圖中各個柱子的高度。每個柱子彼此相鄰,且寬度為 1 。 求在該柱狀圖中,能夠勾勒出來的矩形的最大面積輸入: [2,1,5,6,2,3] 輸出: 10精選題解: (https://leetcode-cn.com/problems/largest-rectangle-in-histogram/solution/zhao-liang-bian-di-yi-ge-xiao-yu-ta-de-zhi-by-powc/)class Solution:def largestRectangleArea(self, heights: List[int]) -> int:stack = []heights = [0] + heights + [0]res = 0for i in range(len(heights)):while stack and heights[stack[-1]] > heights[i]:tmp = stack.pop()res = max(res, (i - stack[-1] - 1) * heights[tmp])stack.append(i)return res4、Leetcode-239-滑動窗口的最大值給定一個數組 nums,有一個大小為 k 的滑動窗口從數組的最左側移動到數組的最右側。你只可以看到在滑動窗口內的 k 個數字。滑動窗口每次只向右移動一位。 返回滑動窗口中的最大值class Solution(object):def maxSlidingWindow(self, nums, k):""":type nums: List[int]:type k: int:rtype: List[int]"""if len(nums) * k == 0:return []return [max(nums[i:i+k]) for i in range(0,len(nums)-k+1)]Mostvotes可查看:https://leetcode.com/problems/sliding-window-maximum/discuss/?currentPage=1&orderBy=most_votes&query=5、Leetcode-641-設計循環雙端隊列設計實現雙端隊列。 你的實現需要支持以下操作:MyCircularDeque(k):構造函數,雙端隊列的大小為k。 insertFront():將一個元素添加到雙端隊列頭部。如果操作成功返回 true。 insertLast():將一個元素添加到雙端隊列尾部。如果操作成功返回 true。 deleteFront():從雙端隊列頭部刪除一個元素。如果操作成功返回 true。 deleteLast():從雙端隊列尾部刪除一個元素。如果操作成功返回 true。 getFront():從雙端隊列頭部獲得一個元素。如果雙端隊列為空,返回 -1。 getRear():獲得雙端隊列的最后一個元素。 如果雙端隊列為空,返回 -1。 isEmpty():檢查雙端隊列是否為空。 isFull():檢查雙端隊列是否滿了。Mostvotes: (https://leetcode.com/problems/design-circular-deque/discuss/154055/python3-using-list-easy-to-understand) class MyCircularDeque:def __init__(self, k):"""Initialize your data structure here. Set the size of the deque to be k.:type k: int"""self._size = 0self._front, self._rear = 0, 0self._capacity = kself._data = [-1] * kdef insertFront(self, value):"""Adds an item at the front of Deque. Return true if the operation is successful.:type value: int:rtype: bool"""if self.isFull():return Falseif self.isEmpty():self._data[self._front] = valueelse:self._front = (self._front - 1) % self._capacityself._data[self._front] = valueself._size += 1return Truedef insertLast(self, value):"""Adds an item at the rear of Deque. Return true if the operation is successful.:type value: int:rtype: bool"""if self.isFull():return Falseif self.isEmpty():self._data[self._rear] = valueelse:self._rear = (self._rear + 1) % self._capacityself._data[self._rear] = valueself._size += 1return Truedef deleteFront(self):"""Deletes an item from the front of Deque. Return true if the operation is successful.:rtype: bool"""if self.isEmpty():return Falseself._data[self._front] = -1self._front = (self._front + 1) % self._capacityself._size -= 1if self.isEmpty():self._rear = self._frontreturn Truedef deleteLast(self):"""Deletes an item from the rear of Deque. Return true if the operation is successful.:rtype: bool"""if self.isEmpty():return Falseself._data[self._rear] = -1self._rear = (self._rear - 1) % self._capacityself._size -= 1if self.isEmpty():self._front = self._rearreturn Truedef getFront(self):"""Get the front item from the deque.:rtype: int"""return self._data[self._front]def getRear(self):"""Get the last item from the deque.:rtype: int"""return self._data[self._rear]def isEmpty(self):"""Checks whether the circular deque is empty or not.:rtype: bool"""return self._size == 0def isFull(self):"""Checks whether the circular deque is full or not.:rtype: bool"""return self._size == self._capacity6、Leetcode-42-接雨水給定 n 個非負整數表示每個寬度為 1 的柱子的高度圖,計算按此排列的柱子,下雨之后能接多少雨水。 下面是由數組 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度圖,在這種情況下,可以接 6 個單位的雨水(藍色部分表示雨水)Mostvotes https://leetcode.com/problems/trapping-rain-water/discuss/17554/Share-my-one-pass-Python-solution-with-explainationdef trap(self, bars):if not bars or len(bars) < 3:return 0volume = 0left, right = 0, len(bars) - 1l_max, r_max = bars[left], bars[right]while left < right:l_max, r_max = max(bars[left], l_max), max(bars[right], r_max)if l_max <= r_max:volume += l_max - bars[left]left += 1else:volume += r_max - bars[right]right -= 1return volume

哈希表、映射、集合部分

哈希表(Hash table),也叫散列表,是根據關鍵碼值(key value)而直接進行訪問的數據結構。它通過把關鍵碼值映射到表中一個位置來訪問記錄,以加快查找的速度。這個映射函數叫做散列函數,存放記錄的數組叫做哈希表(或散列表)。

哈希表復雜度分析:插入、刪除、大部分情況下時間復雜度都是O(1),最壞????情況哈比表的長度比較小,導致多次哈希碰撞,時間復雜度退化成O(n)

1、Leetcode-242-有效的字母異位詞給定兩個字符串 s 和 t ,編寫一個函數來判斷 t 是否是 s 的字母異位詞。 示例 1: 輸入: s = "anagram", t = "nagaram" 輸出: true 示例 2: 輸入: s = "rat", t = "car" 輸出: false 說明: 你可以假設字符串只包含小寫字母。解法: 1、暴力,sorted,兩個字符串是否相等 O(NlogN) 2、hash,map --> 統計每個字符的頻次class Solution:def isAnagram(self, s: str, t: str) -> bool:dict_1 = {}dict_2 = {}for item in s:dict_1[item] = dict_1.get(item,0) + 1for item in t:dict_2[item] = dict_2.get(item,0) + 1return dict_2 == dict_1提交時間 提交結果 執行用時 內存消耗 語言 幾秒前 通過 56 ms 13.5 MB Python32、Leetcode-49-字母異位詞分組給定一個字符串數組,將字母異位詞組合在一起。字母異位詞指字母相同,但排列不同的字符串。 示例: 輸入: ["eat", "tea", "tan", "ate", "nat", "bat"], 輸出: [["ate","eat","tea"],["nat","tan"],["bat"] ] 說明: 所有輸入均為小寫字母。 不考慮答案輸出的順序。class Solution:def groupAnagrams(self, strs: List[str]) -> List[List[str]]:import collectionsdic = collections.defaultdict(list)for c in strs:count = [0] * 26for _ in c:count[ord(_) - ord('a')] += 1dic[tuple(count)].append(c)return dic.values()

樹、二叉樹、二叉搜索樹部分

二維數據結構-樹和圖,區別是否構成環

鏈表是特殊化的樹,樹是特殊化的圖

二叉樹遍歷 Pre-order/In-order/Post-order

1、前序(Pre-order):根-左-右

2、中序(In-order):?左-根-右

3、后序(Post-order): 左-右-根

二叉搜索樹(Binary Search Tree),查詢等操作時間復雜度都是log(n),最壞情況是變成鏈表形式復雜度變為O(n)

二叉搜索樹,也稱有序二叉樹、排序二叉樹,是指一顆空樹或者具有下列性質的二叉樹:

  • 左子樹所有節點的值均小于它的根節點的值

  • 右子樹所有節點的值均大于它的根節點的值

  • 重復:左右子樹也分別為二叉查找樹

  • 1、Leetcode-94-二叉樹中序遍歷給定一個二叉樹,返回它的中序 遍歷。示例:輸入: [1,null,2,3]1\2/3輸出: [1,3,2] 進階: 遞歸算法很簡單,你可以通過迭代算法完成嗎? 解法一:遞歸: # Definition for a binary tree node. # class TreeNode: # def __init__(self, x): # self.val = x # self.left = None # self.right = Noneclass Solution:def inorderTraversal(self, root: TreeNode) -> List[int]:res = []self.helper(root,res)return resdef helper(self,root:TreeNode,res:List):if root:if root.left:self.helper(root.left,res)res.append(root.val)if root.right:self.helper(root.right,res)解法二:顏色標記 (參考:https://leetcode-cn.com/problems/binary-tree-inorder-traversal/solution/yan-se-biao-ji-fa-yi-chong-tong-yong-qie-jian-ming/) # Definition for a binary tree node. # class TreeNode: # def __init__(self, x): # self.val = x # self.left = None # self.right = Noneclass Solution:def inorderTraversal(self, root: TreeNode) -> List[int]:white,Gary = 0,1res = []stack = [(white,root)]while stack:color,node = stack.pop()if node is None:continueif color == white:stack.append((white,node.right))stack.append((Gary,node))stack.append((white,node.left))else:res.append(node.val)return res 2、Leetcode-144-二叉樹前序遍歷# Definition for a binary tree node. # class TreeNode: # def __init__(self, x): # self.val = x # self.left = None # self.right = Noneclass Solution:def preorderTraversal(self, root: TreeNode) -> List[int]:res = []self.helper(root,res)return resdef helper(self,root:TreeNode,res:List):if root:res.append(root.val)if root.left:self.helper(root.left,res)if root.right:self.helper(root.right,res) 3、Leetcode-590-N叉樹的后序遍歷官方題解(https://leetcode-cn.com/problems/n-ary-tree-postorder-traversal/solution/ncha-shu-de-hou-xu-bian-li-by-leetcode/) """ # Definition for a Node. class Node:def __init__(self, val=None, children=None):self.val = valself.children = children """ class Solution:def postorder(self, root: 'Node') -> List[int]:if root is None:return []stack,output = [root],[]while stack:root = stack.pop()if root:output.append(root.val)for c in root.children:stack.append(c)return output[::-1]復雜度分析:時間復雜度:時間復雜度:O(M),其中 M 是 N 叉樹中的節點個數。每個節點只會入棧和出棧各一次。空間復雜度:O(M)。在最壞的情況下,這棵 N 叉樹只有 2 層,所有第 2 層的節點都是根節點的孩子。將根節點推出棧后,需要將這些節點都放入棧,共有 M - 1個節點,因此棧的大小為O(M) 4、Leetcode-589-N叉樹的前序遍歷""" # Definition for a Node. class Node:def __init__(self, val=None, children=None):self.val = valself.children = children """ class Solution:def preorder(self, root: 'Node') -> List[int]:if root is None:return []stack,output = [root],[]while stack:root = stack.pop()output.append(root.val)stack.extend(root.children[::-1])return output時間復雜度與空間復雜度如上分析所示 5、Leetcode-429-N叉樹的層次遍歷""" # Definition for a Node. class Node:def __init__(self, val=None, children=None):self.val = valself.children = children """ class Solution:def levelOrder(self, root: 'Node') -> List[List[int]]:if root is None:return []result,previous_layer = [],[root]while previous_layer:current_layer = []result.append([])for node in previous_layer:result[-1].append(node.val)current_layer.extend(node.children)previous_layer = current_layerreturn result復雜度分析: 時間復雜度:O(n)。n指的是節點的數量。 空間復雜度:O(n)。

    泛型遞歸、樹的遞歸

    遞歸

    遞歸-循環

    通過函數體來進行的循環

    Python 代碼模板def recursion(level,param1,param2,...):# 終止條件if level > MAX_LEVEL:process_resultreturn# 過程邏輯process(level,data...)# 下一層self.recursion(level+1,p1,..思維要點: 1、不要人肉遞歸 2、拆解可重復解決的問題(重復子問題) 3、數學歸納法思維1、Leetcode-70-爬樓梯 假設你正在爬樓梯。需要 n 階你才能到達樓頂。 每次你可以爬 1 或 2 個臺階。你有多少種不同的方法可以爬到樓頂呢? 注意:給定 n 是一個正整數。 示例 1: 輸入:2 輸出:2 解釋:有兩種方法可以爬到樓頂。 1. 1 階 + 1 階 2. 2 階 示例 2: 輸入:3 輸出:3 解釋:有三種方法可以爬到樓頂。 1. 1 階 + 1 階 + 1 階 2. 1 階 + 2 階 3. 2 階 + 1 階class Solution:# 只保存最近的三個值def climbStairs(self, n: int) -> int:if n<=2:return nelse:f1,f2,f3 = 1,2,3for i in range(3,n+1):f3 = f1 + f2f1 = f2f2 = f3return f3 2、Leetcode-22-括號生成 給出 n 代表生成括號的對數,請你寫出一個函數,使其能夠生成所有可能的并且有效的括號組合。例如,給出 n = 3,生成結果為: ["((()))","(()())","(())()","()(())","()()()" ]class Solution:def generateParenthesis(self, n: int) -> List[str]:result = []def recursion(s='',left=0,right=0):if len(s)==2*n:result.append(s)if left < n:recursion(s + '(',left+1,right)if left > right:recursion(s + ')',left,right+1)recursion()return result 3、Leetcode-226-翻轉二叉樹 翻轉一棵二叉樹。 示例: 輸入:4/ \2 7/ \ / \ 1 3 6 9 輸出:4/ \7 2/ \ / \ 9 6 3 1 # Definition for a binary tree node. # class TreeNode: # def __init__(self, x): # self.val = x # self.left = None # self.right = Noneclass Solution:def invertTree(self, root: TreeNode) -> TreeNode:if not root:return Noneroot.left,root.right = root.right,root.leftself.invertTree(root.left)self.invertTree(root.right)return root 4、Leetcode-98-驗證二叉搜索樹給定一個二叉樹,判斷其是否是一個有效的二叉搜索樹。 假設一個二叉搜索樹具有如下特征: 節點的左子樹只包含小于當前節點的數。 節點的右子樹只包含大于當前節點的數。 所有左子樹和右子樹自身必須也是二叉搜索樹。 示例 1: 輸入:2/ \1 3 輸出: true # Definition for a binary tree node. # class TreeNode: # def __init__(self, x): # self.val = x # self.left = None # self.right = Noneclass Solution:def isValidBST(self, root: TreeNode) -> bool:def helper(node,lower = float("-inf"),upper = float("inf")):if not node:return Trueval = node.valif val <= lower or val >= upper:return Falseif not helper(node.left,lower,val):return Falseif not helper(node.right,val,upper):return Falsereturn Truereturn helper(root)時間復雜度為O(N),空間復雜度為O(N) 5、Leetcode-104-二叉樹的最大深度給定一個二叉樹,找出其最大深度。 二叉樹的深度為根節點到最遠葉子節點的最長路徑上的節點數。 class Solution:def maxDepth(self, root: TreeNode) -> int:if not root:return 0return max(self.maxDepth(root.left) + 1, self.maxDepth(root.right)+1) 時間復雜度為O(n),空間復雜度為O(logn),logn為樹的高度 6、Leetcode-111-二叉樹的最小深度 給定一個二叉樹,找出其最小深度。 最小深度是從根節點到最近葉子節點的最短路徑上的節點數量。 說明: 葉子節點是指沒有子節點的節點。 示例: 給定二叉樹 [3,9,20,null,null,15,7],3/ \9 20/ \15 7 返回它的最小深度2方法1: class Solution:def minDepth(self, root: TreeNode) -> int:if not root:return 0if not root.left:return self.minDepth(root.right) + 1if not root.right:return self.minDepth(root.left) + 1return min(self.minDepth(root.left),self.minDepth(root.right)) + 1方法2: class Solution:def minDepth(self, root: TreeNode) -> int:if not root:return 0children = [root.left,root.right]if not any(children):return 1min_d = float("inf")for c in children:if c:min_d = min(self.minDepth(c),min_d)return min_d + 1時間復雜度為O(n),空間復雜度為O(logn) 7、Leetcode-297-二叉樹的序列化與反序列化 序列化是將一個數據結構或者對象轉換為連續的比特位的操作,進而可以將轉換后的數據存儲在一個文件或者內存中,同時也可以通過網絡傳輸到另一個計算機環境,采取相反方式重構得到原數據。 請設計一個算法來實現二叉樹的序列化與反序列化。這里不限定你的序列 / 反序列化算法執行邏輯,你只需要保證一個二叉樹可以被序列化為一個字符串并且將這個字符串反序列化為原始的樹結構。 示例: 你可以將以下二叉樹:1/ \2 3/ \4 5序列化為 "[1,2,3,null,null,4,5]" 官方題解(https://leetcode-cn.com/problems/serialize-and-deserialize-binary-tree/solution/er-cha-shu-de-xu-lie-hua-yu-fan-xu-lie-hua-by-leet/) # Definition for a binary tree node. # class TreeNode(object): # def __init__(self, x): # self.val = x # self.left = None # self.right = None class Codec:def serialize(self, root):"""Encodes a tree to a single string.:type root: TreeNode:rtype: str"""def rserialize(root,string):if root is None:string += "None,"else:string += str(root.val) + ","string = rserialize(root.left,string)string = rserialize(root.right,string)return stringreturn rserialize(root,"")def deserialize(self, data):"""Decodes your encoded data to tree.:type data: str:rtype: TreeNode"""def rdeserialize(l):if l[0] == "None":l.pop(0)return Noneroot = TreeNode(l[0])l.pop(0)root.left = rdeserialize(l)root.right = rdeserialize(l)return rootdata_list = data.split(',')root = rdeserialize(data_list)return root時間復雜度為O(n),空間復雜度為O(n) # Your Codec object will be instantiated and called as such: # codec = Codec() # codec.deserialize(codec.serialize(root)) 8、Leetcode-236-二叉樹的最近公共祖先 給定一個二叉樹, 找到該樹中兩個指定節點的最近公共祖先。 百度百科中最近公共祖先的定義為:“對于有根樹 T 的兩個結點 p、q,最近公共祖先表示為一個結點 x,滿足 x 是 p、q 的祖先且 x 的深度盡可能大(一個節點也可以是它自己的祖先)。” 例如,給定如下二叉樹: root = [3,5,1,6,2,0,8,null,null,7,4]示例 1: 輸入: root = [3,5,1,6,2,0,8,null,null,7,4], p = 5, q = 1 輸出: 3 解釋: 節點 5 和節點 1 的最近公共祖先是節點 3。官方題解(https://leetcode-cn.com/problems/lowest-common-ancestor-of-a-binary-tree/solution/er-cha-shu-de-zui-jin-gong-gong-zu-xian-by-leetcod/) # Definition for a binary tree node. # class TreeNode: # def __init__(self, x): # self.val = x # self.left = None # self.right = Noneclass Solution:def __init__(self):self.ans = Nonedef lowestCommonAncestor(self, root: 'TreeNode', p: 'TreeNode', q: 'TreeNode') -> 'TreeNode':def recurse_tree(current_node):if not current_node:return Falseleft = recurse_tree(current_node.left)right = recurse_tree(current_node.right)mid = current_node == p or current_node == qif mid + left + right >= 2:self.ans = current_nodereturn mid or left or rightrecurse_tree(root)return self.ans時間復雜度O(n),空間復雜度O(n)9、Leetcode-105-從前序與中序遍歷序列構造二叉樹 根據一棵樹的前序遍歷與中序遍歷構造二叉樹。 注意: 你可以假設樹中沒有重復的元素。 例如,給出 前序遍歷 preorder = [3,9,20,15,7] 中序遍歷 inorder = [9,3,15,20,7] 返回如下的二叉樹:3/ \9 20/ \15 7class Solution:def buildTree(self, preorder: List[int], inorder: List[int]) -> TreeNode:if len(inorder) == 0:return Noneroot = TreeNode(preorder[0])mid = inorder.index(preorder[0])root.left = self.buildTree(preorder[1:mid+1],inorder[:mid])root.right = self.buildTree(preorder[mid+1:],inorder[mid+1:])return root 10、Leetcode-77-組合給定兩個整數 n 和 k,返回 1 ... n 中所有可能的 k 個數的組合。 示例: 輸入: n = 4, k = 2 輸出: [[2,4],[3,4],[2,3],[1,2],[1,3],[1,4], ] class Solution:def combine(self, n: int, k: int) -> List[List[int]]:def backtrack(first = 1,curr = []):if len(curr) == k:output.append(curr[:])for i in range(first,n+1):curr.append(i)backtrack(i+1,curr)curr.pop()output = []backtrack()return output 11、Leetcode-46-全排列給定一個沒有重復數字的序列,返回其所有可能的全排列。 示例: 輸入: [1,2,3] 輸出: [[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1] ]class Solution:def permute(self, nums: List[int]) -> List[List[int]]:def backtrack(first=0):if first == n:output.append(nums[:])for i in range(first,n):nums[first],nums[i] = nums[i],nums[first]backtrack(first+1)nums[i],nums[first] = nums[first],nums[i]n = len(nums)output = []backtrack()return output

    分治、回溯部分

    分治、回溯是遞歸的一種,本質是將重復性問題分解以及最后組合每個子問題的結果

    分治代碼模板: def divide_conquer(problem,param1,param2,...):# 遞歸終止條件if problem is None:print_resultreturn# 準備數據data = prepare_data(problem)subproblems = split_problem(problem,data)# 分治 子問題subresult1 = self.divide_conquer(subproblems[0],p1,...)subresult2 = self.divide_conquer(subproblems[1],p1,...)subresult3 = self.divide_conquer(subproblems[2],p1,...)..... # 收集子結果產生最后的結果result = process_result(subresult1,subresult2,..)# 清除當前層的狀態回溯,是簡單的一層一層去試探1、Leetcode-50-Pow(x,n) 實現 pow(x, n) ,即計算 x 的 n 次冪函數。 示例 1: 輸入: 2.00000, 10 輸出: 1024.00000 示例 2: 輸入: 2.10000, 3 輸出: 9.26100class Solution:def myPow(self, x: float, n: int) -> float:def helper(x,n):if n==0:return 1.0if n%2==0:return helper(x*x,n/2)else:return helper(x*x,(n-1)/2)*xif n<0:n = -nreturn 1/helper(x,n)return helper(x,n) 2、Leetcode-78-子集 給定一組不含重復元素的整數數組 nums,返回該數組所有可能的子集(冪集)。 說明:解集不能包含重復的子集。 示例: 輸入: nums = [1,2,3] 輸出: [[3],[1],[2],[1,2,3],[1,3],[2,3],[1,2],[] ] class Solution:def subsets(self, nums: List[int]) -> List[List[int]]:results = [[]]for num in nums:newsets = []for subset in results:new_subset = subset + [num]newsets.append(new_subset)results.extend(newsets)return resultsclass Solution:def subsets(self, nums: List[int]) -> List[List[int]]:res = [[]]for i in nums:res = res + [[i] + num for num in res]return res 3、Leetcode-169-多數元素給定一個大小為 n 的數組,找到其中的多數元素。多數元素是指在數組中出現次數大于 ? n/2 ? 的元素。 你可以假設數組是非空的,并且給定的數組總是存在多數元素。示例 1: 輸入: [3,2,3] 輸出: 3 分治法class Solution:def majorityElement(self, nums: List[int]) -> int:def majority_element_rec(first,end):if first == end:return nums[first]mid = (end-first)//2 + firstleft = majority_element_rec(first,mid)right = majority_element_rec(mid+1,end)if left == right:return leftleft_count = sum([1 for i in range(first,end+1) if nums[i]==left])right_count = sum([1 for i in range(first,end+1) if nums[i]==right])return left if left_count > right_count else rightreturn majority_element_rec(0,len(nums)-1)時間復雜度O(nlogn),空間復雜度O(n) 4、Leetcode-17-電話號碼的字母組合 給定一個僅包含數字 2-9 的字符串,返回所有它能表示的字母組合。 給出數字到字母的映射如下(與電話按鍵相同)。注意 1 不對應任何字母。class Solution:def letterCombinations(self, digits: str) -> List[str]:phone = {"2":["a","b","c"],"3":["d","e","f"],"4":["g","h","i"],"5":["j","k","l"],"6":["m","n","o"],"7":["p","q","r","s"],"8":["t","u","v"],"9":["w","x","y","z"]}output = []def backtrack(combinations,next_digits):if len(next_digits)==0:output.append(combinations)else:for letter in phone[next_digits[0]]:backtrack(combinations + letter,next_digits[1:])if digits:backtrack("",digits)return output 5、Leetcode-51-N皇后問題 n 皇后問題研究的是如何將 n 個皇后放置在 n×n 的棋盤上,并且使皇后彼此之間不能相互攻擊。 給定一個整數 n,返回所有不同的 n 皇后問題的解決方案。 每一種解法包含一個明確的 n 皇后問題的棋子放置方案,該方案中 'Q' 和 '.' 分別代表了皇后和空位。 示例: 輸入: 4 輸出: [[".Q..", // 解法 1"...Q","Q...","..Q."],["..Q.", // 解法 2"Q...","...Q",".Q.."] ] 解釋: 4 皇后問題存在兩個不同的解法。 官方題解(https://leetcode-cn.com/problems/n-queens/solution/nhuang-hou-by-leetcode/) class Solution:def solveNQueens(self, n: int) -> List[List[str]]:def could_place(row, col):return not (cols[col] + hill_diagonals[row - col] + dale_diagonals[row + col])def place_queen(row, col):queens.add((row, col))cols[col] = 1hill_diagonals[row - col] = 1dale_diagonals[row + col] = 1def remove_queen(row, col):queens.remove((row, col))cols[col] = 0hill_diagonals[row - col] = 0dale_diagonals[row + col] = 0def add_solution():solution = []for _, col in sorted(queens):solution.append('.' * col + 'Q' + '.' * (n - col - 1))output.append(solution)def backtrack(row = 0):for col in range(n):if could_place(row, col):place_queen(row, col)if row + 1 == n:add_solution()else:backtrack(row + 1)remove_queen(row, col)cols = [0] * nhill_diagonals = [0] * (2 * n - 1)dale_diagonals = [0] * (2 * n - 1)queens = set()output = []backtrack()return output

    深度優先搜索、廣度優先搜索

    遍歷搜索:在樹(圖/狀態集)中尋找特定節點

    搜索-遍歷:

    • 每個節點都要訪問一次

    • 每個節點僅僅要訪問一次

    • 對于節點的訪問順序不限:深度優先、廣度優先

    示例代碼: def dfs(node):if node in visited:returnvisited.add(node)dfs(node.left)dfs(node.right)深度優先搜索 DFS代碼-遞歸寫法: visited = set() def dfs(node,visited):if node in visited:returnvisited.add(node)for next_node in node.children():if not next_node in visited:dfs(next node,visited)DFS代碼-非遞歸寫法def DFS(self,tree):if tree.root is None:return []visited,stack = [],[tree.root]while stack:node = stack.pop()visited.add(node)process(node)nodes = generage_related_node(node)stack.push(nodes) 廣度優先搜索 BFS代碼-遞歸 visited = set() def dfs(node,visited):visited.add(node)for next_node in node.children():if next_node not in visited:dfs(next_node,visited)BFS代碼-非遞歸 dfs BFS(graph,start,end):queue = []queue.append([start])visited.add(start)while queue:node = queue.pop()visited.add(node)process(node)nodes = generate_related_nodes(node)queue.push(nodes) 1、Leetcode-102-二叉樹的層次遍歷 給定一個二叉樹,返回其按層次遍歷的節點值。 (即逐層地,從左到右訪問所有節點)。例如: 給定二叉樹: [3,9,20,null,null,15,7],3/ \9 20/ \15 7 返回其層次遍歷結果:[[3],[9,20],[15,7] ]解法一:class Solution:def levelOrder(self, root: TreeNode) -> List[List[int]]:ans,level = [],[root]while root and level:ans.append([node.val for node in level])LRpair = [(node.left,node.right) for node in level]level = [leaf for LR in LRpair for leaf in LR if leaf]return ans解法二:BFSclass Solution:def levelOrder(self, root: TreeNode) -> List[List[int]]:from collections import dequeif not root:return []queue,res = deque([root]),[]while queue:cur_level,size = [],len(queue)for i in range(size):node = queue.popleft()if node.left:queue.append(node.left)if node.right:queue.append(node.right)cur_level.append(node.val)res.append(cur_level)return res 2、Leetcode-433-最小基因變化 一條基因序列由一個帶有8個字符的字符串表示,其中每個字符都屬于 "A", "C", "G", "T"中的任意一個。 假設我們要調查一個基因序列的變化。一次基因變化意味著這個基因序列中的一個字符發生了變化。 例如,基因序列由"AACCGGTT" 變化至 "AACCGGTA" 即發生了一次基因變化。 與此同時,每一次基因變化的結果,都需要是一個合法的基因串,即該結果屬于一個基因庫。 現在給定3個參數 — start, end, bank,分別代表起始基因序列,目標基因序列及基因庫,請找出能夠使起始基因序列變化為目標基因序列所需的最少變化次數。如果無法實現目標變化,請返回 -1。注意: 起始基因序列默認是合法的,但是它并不一定會出現在基因庫中。 所有的目標基因序列必須是合法的。 假定起始基因序列與目標基因序列是不一樣的。 示例 1: start: "AACCGGTT" end: "AACCGGTA" bank: ["AACCGGTA"] 返回值: 1示例 2: start: "AACCGGTT" end: "AAACGGTA" bank: ["AACCGGTA", "AACCGCTA", "AAACGGTA"] 返回值: 2示例 3: start: "AAAAACCC" end: "AACCCCCC" bank: ["AAAACCCC", "AAACCCCC", "AACCCCCC"] 返回值: 3 BFSclass Solution:def minMutation(self, start: str, end: str, bank: List[str]) -> int:bank = set(bank)if end not in bank:return -1q = [(start,0)]change = {'A':'TCG','T':'ACG','C':'ATG','G':'ATC'}while q:node,step = q.pop(0)if node == end:return stepfor i,v in enumerate(node):for j in change[v]:new = node[:i] + j + node[i+1:]if new in bank:q.append((new,step+1))bank.remove(new)return -1 3、Leetcode-22-括號生成給出 n 代表生成括號的對數,請你寫出一個函數,使其能夠生成所有可能的并且有效的括號組合。 例如,給出 n = 3,生成結果為: ["((()))","(()())","(())()","()(())","()()()" ] class Solution:def generateParenthesis(self, n: int) -> List[str]:res = []def dfs(leftRemain,rightRemain,path,res):if leftRemain > rightRemain or leftRemain < 0 or rightRemain < 0:returnif leftRemain == 0 and rightRemain == 0:res.append(path)returndfs(leftRemain - 1, rightRemain, path + "(", res)dfs(leftRemain, rightRemain-1, path + ")", res)dfs(n,n,"",res)return res 4、Leetcode-515-在每個樹行中找到最大值您需要在二叉樹的每一行中找到最大的值。示例:輸入: 1/ \3 2/ \ \ 5 3 9 輸出: [1, 3, 9]class Solution:def largestValues(self, root: TreeNode) -> List[int]:from collections import dequequeue = deque([root])res = []if not root:return []while queue:cur_level,size = [],len(queue)for i in range(size):node = queue.popleft()if node.left:queue.append(node.left)if node.right:queue.append(node.right)cur_level.append(node.val)res.append(max(cur_level))return res 5、Leetcode-127-單詞接龍 給定兩個單詞(beginWord 和 endWord)和一個字典,找到從 beginWord 到 endWord 的最短轉換序列的長度。轉換需遵循如下規則:每次轉換只能改變一個字母。 轉換過程中的中間單詞必須是字典中的單詞。 說明: 如果不存在這樣的轉換序列,返回 0。 所有單詞具有相同的長度。 所有單詞只由小寫字母組成。 字典中不存在重復的單詞。 你可以假設 beginWord 和 endWord 是非空的,且二者不相同。 示例 1:輸入: beginWord = "hit", endWord = "cog", wordList = ["hot","dot","dog","lot","log","cog"]輸出: 5 解釋: 一個最短轉換序列是 "hit" -> "hot" -> "dot" -> "dog" -> "cog",返回它的長度 5。class Solution:def ladderLength(self, beginWord: str, endWord: str, wordList: List[str]) -> int:wordList.append(endWord)queue = collections.deque([[beginWord,1]])while queue:word,length = queue.popleft()if word == endWord:return lengthfor i in range(len(word)):for c in 'abcdefghijklmnopqrstuvwxyz':next_word = word[:i] + c + word[i+1:]if next_word in wordList:wordList.remove(next_word)queue.append([next_word,length+1])return 0 6、Leetcode-126-單詞接龍II 給定兩個單詞(beginWord 和 endWord)和一個字典 wordList,找出所有從 beginWord 到 endWord 的最短轉換序列。轉換需遵循如下規則:每次轉換只能改變一個字母。 轉換過程中的中間單詞必須是字典中的單詞。 說明: 如果不存在這樣的轉換序列,返回一個空列表。 所有單詞具有相同的長度。 所有單詞只由小寫字母組成。 字典中不存在重復的單詞。 你可以假設 beginWord 和 endWord 是非空的,且二者不相同。 示例 1:輸入: beginWord = "hit", endWord = "cog", wordList = ["hot","dot","dog","lot","log","cog"]輸出: [["hit","hot","dot","dog","cog"],["hit","hot","lot","log","cog"] ] MostVotes(https://leetcode.com/problems/word-ladder-ii/discuss/40482/Python-simple-BFS-layer-by-layer) class Solution:def findLadders(self, beginWord: str, endWord: str, wordList: List[str]) -> List[List[str]]:wordList = set(wordList)res = []layer = {}layer[beginWord] = [[beginWord]]while layer:newlayer = collections.defaultdict(list)for w in layer:if w == endWord: res.extend(k for k in layer[w])else:for i in range(len(w)):for c in 'abcdefghijklmnopqrstuvwxyz':neww = w[:i]+c+w[i+1:]if neww in wordList:newlayer[neww]+=[j+[neww] for j in layer[w]]wordList -= set(newlayer.keys())layer = newlayerreturn res 7、Leetcode-200-島嶼數量 給定一個由 '1'(陸地)和 '0'(水)組成的的二維網格,計算島嶼的數量。一個島被水包圍,并且它是通過水平方向或垂直方向上相鄰的陸地連接而成的。你可以假設網格的四個邊均被水包圍。示例 1:輸入: 11110 11010 11000 00000輸出: 1 示例 2:輸入: 11000 11000 00100 00011輸出: 3 MostVotes(https://leetcode.com/problems/number-of-islands/discuss/56340/Python-Simple-DFS-Solution)class Solution:def numIslands(self, grid: List[List[str]]) -> int:if not grid:return 0count = 0for i in range(len(grid)):for j in range(len(grid[0])):if grid[i][j] == '1':self.dfs(grid, i, j)count += 1return countdef dfs(self, grid, i, j):if i<0 or j<0 or i>=len(grid) or j>=len(grid[0]) or grid[i][j] != '1':returngrid[i][j] = '#'self.dfs(grid, i+1, j)self.dfs(grid, i-1, j)self.dfs(grid, i, j+1)self.dfs(grid, i, j-1) 8、Leetcode-529-掃雷游戲 讓我們一起來玩掃雷游戲! 給定一個代表游戲板的二維字符矩陣。 'M' 代表一個未挖出的地雷,'E' 代表一個未挖出的空方塊,'B' 代表沒有相鄰(上,下,左,右,和所有4個對角線)地雷的已挖出的空白方塊,數字('1' 到 '8')表示有多少地雷與這塊已挖出的方塊相鄰,'X' 則表示一個已挖出的地雷。 現在給出在所有未挖出的方塊中('M'或者'E')的下一個點擊位置(行和列索引),根據以下規則,返回相應位置被點擊后對應的面板: 如果一個地雷('M')被挖出,游戲就結束了- 把它改為 'X'。 如果一個沒有相鄰地雷的空方塊('E')被挖出,修改它為('B'),并且所有和其相鄰的方塊都應該被遞歸地揭露。 如果一個至少與一個地雷相鄰的空方塊('E')被挖出,修改它為數字('1'到'8'),表示相鄰地雷的數量。 如果在此次點擊中,若無更多方塊可被揭露,則返回面板。示例 1: 輸入: [['E', 'E', 'E', 'E', 'E'],['E', 'E', 'M', 'E', 'E'],['E', 'E', 'E', 'E', 'E'],['E', 'E', 'E', 'E', 'E']]Click : [3,0] 輸出: [['B', '1', 'E', '1', 'B'],['B', '1', 'M', '1', 'B'],['B', '1', '1', '1', 'B'],['B', 'B', 'B', 'B', 'B']]MostVotes(https://leetcode.com/problems/minesweeper/discuss/137802/Python-DFS-solution)class Solution:def updateBoard(self, board: List[List[str]], click: List[int]) -> List[List[str]]:if not board:return []m, n = len(board), len(board[0])i, j = click[0], click[1]# If a mine ('M') is revealed, then the game is over - change it to 'X'.if board[i][j] == 'M':board[i][j] = 'X'return board# run dfs to reveal the boardself.dfs(board, i, j)return boarddef dfs(self, board, i, j):if board[i][j] != 'E':returnm, n = len(board), len(board[0]) directions = [(-1,-1), (0,-1), (1,-1), (1,0), (1,1), (0,1), (-1,1), (-1,0)]mine_count = 0for d in directions:ni, nj = i + d[0], j + d[1]if 0 <= ni < m and 0 <= nj < n and board[ni][nj] == 'M': mine_count += 1if mine_count == 0:board[i][j] = 'B'else:board[i][j] = str(mine_count)returnfor d in directions:ni, nj = i + d[0], j + d[1]if 0 <= ni < m and 0 <= nj < n:self.dfs(board, ni, nj)

    二分查找部分

    二分查找的前提

    1、目標函數單調性(單調遞增或遞減)

    2、存在上下界(bound)

    3、能夠通過索引訪問(index accessible)

    代碼模板: left,right = 0,len(array)-1 while left <= right:mid = (left + right)/2if array[mid] == target:# find the targetbreak or return resultelif array[mid] < target:left = mid + 1else:right = mid - 11、Leetcode-69-x的平方根 實現 int sqrt(int x) 函數。 計算并返回 x 的平方根,其中 x 是非負整數。 由于返回類型是整數,結果只保留整數的部分,小數部分將被舍去。 示例 1: 輸入: 4 輸出: 2二分查找法 class Solution:def mySqrt(self, x: int) -> int:left,right = 0,x//2 + 1while left < right:mid = left + (right-left+1)//2if mid*mid > x:right = mid -1else:left = mid return left牛頓法 class Solution:def mySqrt(self, x: int) -> int:r = xwhile r*r > x:r = (r+x//r)//2return r2、Leetcode-367-有效的完全平方數 給定一個正整數 num,編寫一個函數,如果 num 是一個完全平方數,則返回 True,否則返回 False。 說明:不要使用任何內置的庫函數,如 sqrt。 示例 1: 輸入:16 輸出:True 示例 2: 輸入:14 輸出:False class Solution:def isPerfectSquare(self, num: int) -> bool:x = numwhile x*x>num:x = (x + num//x)//2if x*x==num:return Truereturn False3、Leetcode-33-搜索旋轉排序數組 假設按照升序排序的數組在預先未知的某個點上進行了旋轉。( 例如,數組 [0,1,2,4,5,6,7] 可能變為 [4,5,6,7,0,1,2] )。搜索一個給定的目標值,如果數組中存在這個目標值,則返回它的索引,否則返回 -1 。 你可以假設數組中不存在重復的元素。 你的算法時間復雜度必須是 O(log n) 級別。示例 1: 輸入: nums = [4,5,6,7,0,1,2], target = 0 輸出: 4 class Solution:def search(self, nums: List[int], target: int) -> int:left,right = 0,len(nums)-1while left < right:mid = left + (right - left)//2if nums[0] <= nums[mid] and (target > nums[mid] or target < nums[0]):left = mid + 1elif(target > nums[mid] and target < nums[0]):left = mid + 1else:right = midif left == right and nums[left] == target: return leftreturn -1 4、編寫一個高效的算法來判斷 m x n 矩陣中,是否存在一個目標值。該矩陣具有如下特性: 每行中的整數從左到右按升序排列。 每行的第一個整數大于前一行的最后一個整數。 示例 1:輸入: matrix = [[1, 3, 5, 7],[10, 11, 16, 20],[23, 30, 34, 50] ] target = 3 輸出: true class Solution:def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:if len(matrix)==0:return Falsei,row,col = 0,len(matrix)-1,len(matrix[0])-1while i <= row and 0 <=col:if matrix[i][col]>target:col -= 1elif matrix[i][col]==target:return Trueelse:i += 1return False 5、Leetcode-153-尋找旋轉數組中的最小值 假設按照升序排序的數組在預先未知的某個點上進行了旋轉。 ( 例如,數組 [0,1,2,4,5,6,7] 可能變為 [4,5,6,7,0,1,2] )。 請找出其中最小的元素。 你可以假設數組中不存在重復元素。 示例 1: 輸入: [3,4,5,1,2] 輸出: 1 示例 2: 輸入: [4,5,6,7,0,1,2] 輸出: 0 class Solution:def findMin(self, nums: List[int]) -> int:if len(nums) == 1:return nums[0]left,right = 0,len(nums)-1if nums[right] > nums[0]:return nums[0]while left <= right:mid = left + (right - left)//2if nums[mid] > nums[mid+1]:return nums[mid+1]if nums[mid-1] > nums[mid]:return nums[mid]if nums[mid] > nums[0]:left = mid + 1else:right = mid - 1

    貪心算法部分

    貪心算法是一種在每一步選擇中都采取在當前狀態下最好或最優的選擇,從而希望導致結果是全局最好或最優的算法。簡單地說,問題能夠分解成子問題來解決,子問題的最優解能遞推到最終問題的最優解,這種子問題最優解成為最優子結構。貪心算法與動態規劃的不同在于它對每個子問題的解決方案都作出選擇不能回退。動態規劃則會保存以前的運算結果,并根據以前的結果對當前進行選擇,有回退功能。

    1、Leetcode-455-分發餅干 假設你是一位很棒的家長,想要給你的孩子們一些小餅干。但是,每個孩子最多只能給一塊餅干。對每個孩子 i ,都有一個胃口值 gi ,這是能讓孩子們滿足胃口的餅干的最小尺寸;并且每塊餅干 j ,都有一個尺寸 sj 。如果 sj >= gi ,我們可以將這個餅干 j 分配給孩子 i ,這個孩子會得到滿足。你的目標是盡可能滿足越多數量的孩子,并輸出這個最大數值。 注意: 你可以假設胃口值為正。 一個小朋友最多只能擁有一塊餅干。 示例 1: 輸入: [1,2,3], [1,1] 輸出: 1 解釋: 你有三個孩子和兩塊小餅干,3個孩子的胃口值分別是:1,2,3。 雖然你有兩塊小餅干,由于他們的尺寸都是1,你只能讓胃口值是1的孩子滿足。 所以你應該輸出1。 貪心算法 class Solution:def findContentChildren(self, g: List[int], s: List[int]) -> int:g.sort()s.sort()child = 0cookie = 0while child < len(g) and cookie < len(s):if g[child] <= s[cookie]:child += 1cookie += 1return child2、Leetcode-122-買股票的最佳時機II 給定一個數組,它的第 i 個元素是一支給定股票第 i 天的價格。 設計一個算法來計算你所能獲取的最大利潤。你可以盡可能地完成更多的交易(多次買賣一支股票)。 注意:你不能同時參與多筆交易(你必須在再次購買前出售掉之前的股票)。示例 1:輸入: [7,1,5,3,6,4] 輸出: 7 解釋: 在第 2 天(股票價格 = 1)的時候買入,在第 3 天(股票價格 = 5)的時候賣出, 這筆交易所能獲得利潤 = 5-1 = 4 。隨后,在第 4 天(股票價格 = 3)的時候買入,在第 5 天(股票價格 = 6)的時候賣出, 這筆交易所能獲得利潤 = 6-3 = 3 。class Solution:def maxProfit(self, prices: List[int]) -> int:total = 0for i in range(len(prices)-1):if prices[i+1] > prices[i]:total += (prices[i+1]-prices[i])return total3、Leetcode-55-跳躍游戲 給定一個非負整數數組,你最初位于數組的第一個位置。 數組中的每個元素代表你在該位置可以跳躍的最大長度。 判斷你是否能夠到達最后一個位置。示例 1: 輸入: [2,3,1,1,4] 輸出: true 解釋: 我們可以先跳 1 步,從位置 0 到達 位置 1, 然后再從位置 1 跳 3 步到達最后一個位置。class Solution:def canJump(self, nums: List[int]) -> bool:endLength = len(nums) - 1for i in range(len(nums)-1,-1,-1):if nums[i] + i >= endLength:endLength = ireturn endLength == 04、Leetcode-860-檸檬水找零在檸檬水攤上,每一杯檸檬水的售價為 5 美元。 顧客排隊購買你的產品,(按賬單 bills 支付的順序)一次購買一杯。 每位顧客只買一杯檸檬水,然后向你付 5 美元、10 美元或 20 美元。你必須給每個顧客正確找零,也就是說凈交易是每位顧客向你支付 5 美元。 注意,一開始你手頭沒有任何零錢。 如果你能給每位顧客正確找零,返回 true ,否則返回 false 。示例 1: 輸入:[5,5,5,10,20] 輸出:true 解釋: 前 3 位顧客那里,我們按順序收取 3 張 5 美元的鈔票。 第 4 位顧客那里,我們收取一張 10 美元的鈔票,并返還 5 美元。 第 5 位顧客那里,我們找還一張 10 美元的鈔票和一張 5 美元的鈔票。 由于所有客戶都得到了正確的找零,所以我們輸出 true。class Solution:def lemonadeChange(self, bills: List[int]) -> bool:five,ten = 0,0for bill in bills:if bill == 5:five += 1elif bill == 10:if not five:return Falsefive -= 1ten += 1else:if five and ten:five -= 1ten -= 1elif five>=3:five -= 3else:return Falsereturn True5、Leetcode-874-模擬行走機器人機器人在一個無限大小的網格上行走,從點 (0, 0) 處開始出發,面向北方。該機器人可以接收以下三種類型的命令: -2:向左轉 90 度 -1:向右轉 90 度 1 <= x <= 9:向前移動 x 個單位長度 在網格上有一些格子被視為障礙物。 第 i 個障礙物位于網格點 (obstacles[i][0], obstacles[i][1]) 如果機器人試圖走到障礙物上方,那么它將停留在障礙物的前一個網格方塊上,但仍然可以繼續該路線的其余部分。 返回從原點到機器人的最大歐式距離的平方。 示例 1:輸入: commands = [4,-1,3], obstacles = [] 輸出: 25 解釋: 機器人將會到達 (3, 4)class Solution:def robotSim(self, commands: List[int], obstacles: List[List[int]]) -> int:dx,dy,x,y = 0,1,0,0distance = 0obs_dict = {}for obs in obstacles:obs_dict[tuple(obs)] = 0for com in commands:if com == -2:dx,dy = -dy,dxelif com == -1:dx,dy = dy,-dxelse:for j in range(com):next_x = x + dxnext_y = y + dyif (next_x,next_y) in obs_dict:breakx,y = next_x,next_ydistance = max(distance,x*x+y*y)return distance6、Leetcode-45-跳躍游戲II 給定一個非負整數數組,你最初位于數組的第一個位置。 數組中的每個元素代表你在該位置可以跳躍的最大長度。 你的目標是使用最少的跳躍次數到達數組的最后一個位置。示例: 輸入: [2,3,1,1,4] 輸出: 2 解釋: 跳到最后一個位置的最小跳躍數是 2。從下標為 0 跳到下標為 1 的位置,跳 1 步,然后跳 3 步到達數組的最后一個位置。class Solution:def jump(self, nums: List[int]) -> int:if nums.count(1) == len(nums):return len(nums)-1def fun(n):if not n:return 0for k,v in enumerate(n):if v + k >= len(n):return fun(n[:k]) + 1return fun(nums[:-1])

    動態規劃部分

    動態規劃和遞歸或者分治沒有根本上的區別(關鍵看有無最優的子結構)

    共性:找到重復子問題

    差異性:最優子結構、中途可以淘汰次優解

    Bottom Up- 自底向上 F[n] = F[n-1] + F[n-2] a[0] = 0, a[1] = 1 for i in range(2,n+1):a[i] = a[i-1] + a[i-2]a[n] 0,1,1,2,3,5,8,13狀態轉移方程(DP方程) opt[i,j] = opt[i+1,j] + opt[i,j+1] 完整邏輯: if a[i,j]='空地':opt[i,j] = opt[i+1,j] + opt[i,j+1] else opt[i,j]=0動態規劃關鍵點: 1、最優子結構 opt[n] = best_od(opt[n-1],opt[n-2],...) 2、存儲中間狀態: opt[i] 3、遞推公式: Fib: opt[i] = opt[n-1] + opt[n-2] 二維路徑: opt[i,j] = opt[i+1][j] + opt[i][j+1](且判斷a[i,j]是否空地)1、Leetcode-62-不同路徑 一個機器人位于一個 m x n 網格的左上角 (起始點在下圖中標記為“Start” )。 機器人每次只能向下或者向右移動一步。機器人試圖達到網格的右下角(在下圖中標記為“Finish”)。 問總共有多少條不同的路徑? 示例 1: 輸入: m = 3, n = 2 輸出: 3 解釋: 從左上角開始,總共有 3 條路徑可以到達右下角。 1. 向右 -> 向右 -> 向下 2. 向右 -> 向下 -> 向右 3. 向下 -> 向右 -> 向右 方法:動態規劃 思路:第一行 + 第一列都是在邊界,所以只能為1 + 動態方程class Solution:def uniquePaths(self, m: int, n: int) -> int:dp = [[0]*n]*mfor i in range(m):dp[i][0] = 1for j in range(n):dp[0][j] = 1for i in range(1,m):for j in range(1,n):dp[i][j] = dp[i-1][j] + dp[i][j-1]return dp[-1][-1] 2、Leetcode-1143-最長公共子序列給定兩個字符串 text1 和 text2,返回這兩個字符串的最長公共子序列。 一個字符串的 子序列 是指這樣一個新的字符串:它是由原字符串在不改變字符的相對順序的情況下刪除某些字符(也可以不刪除任何字符)后組成的新字符串。 例如,"ace" 是 "abcde" 的子序列,但 "aec" 不是 "abcde" 的子序列。兩個字符串的「公共子序列」是這兩個字符串所共同擁有的子序列。 若這兩個字符串沒有公共子序列,則返回 0。 示例 1: 輸入:text1 = "abcde", text2 = "ace" 輸出:3 解釋:最長公共子序列是 "ace",它的長度為 3 class Solution:def longestCommonSubsequence(self, text1: str, text2: str) -> int:if not text1 or not text2:return 0m,n = len(text1),len(text2)dp = [[0]*(n+1) for _ in range(m+1)]for i in range(1,m+1):for j in range(1,n+1):if text1[i-1] == text2[j-1]:dp[i][j] = 1 + dp[i-1][j-1]else:dp[i][j] = max(dp[i-1][j],dp[i][j-1])return dp[m][n] 3、Leetcode-120-三角形最小路徑和給定一個三角形,找出自頂向下的最小路徑和。每一步只能移動到下一行中相鄰的結點上。 例如,給定三角形: [[2],[3,4],[6,5,7],[4,1,8,3] ] 自頂向下的最小路徑和為 11(即,2 + 3 + 5 + 1 = 11) class Solution:def minimumTotal(self, triangle: List[List[int]]) -> int:"""dp[i][j] = triangle[i][j] + min(dp[i+1][j],dp[i+1][j+1])"""dp = trianglefor i in range(len(triangle)-2,-1,-1):for j in range(len(triangle[i])):dp[i][j] += min(dp[i+1][j],dp[i+1][j+1])return dp[0][0] 4、Leetcode-53-最大子序和給定一個整數數組 nums ,找到一個具有最大和的連續子數組(子數組最少包含一個元素),返回其最大和。 示例: 輸入: [-2,1,-3,4,-1,2,1,-5,4], 輸出: 6 解釋: 連續子數組 [4,-1,2,1] 的和最大,為 6。class Solution:def maxSubArray(self, nums: List[int]) -> int:for i in range(1,len(nums)):nums[i] = max(nums[i-1],0) + nums[i]return max(nums) 5、Leetcode-152-乘積最大子序列 給定一個整數數組 nums ,找出一個序列中乘積最大的連續子序列(該序列至少包含一個數)。 示例 1: 輸入: [2,3,-2,4] 輸出: 6 解釋: 子數組 [2,3] 有最大乘積 6。 示例 2: 輸入: [-2,0,-1] 輸出: 0 解釋: 結果不能為 2, 因為 [-2,-1] 不是子數組。 class Solution:def maxProduct(self,nums:List[int])->int:ma,mi,res = nums[0]if nums[i]<0:ma,mi = mi,mafor i in range(len(nums)):ma = max(ma*nums[i],nums[i])mi = min(mi*nums[i],nums[i])res = max(res,ma)return res 6、Leetcode-322-零錢兌換 給定不同面額的硬幣 coins 和一個總金額 amount。編寫一個函數來計算可以湊成總金額所需的最少的硬幣個數。如果沒有任何一種硬幣組合能組成總金額,返回 -1。 示例 1: 輸入: coins = [1, 2, 5], amount = 11 輸出: 3 解釋: 11 = 5 + 5 + 1 class Solution:def coinChange(self, coins: List[int], amount: int) -> int:"""f(n) = min{f(n-k),k in [1,2,5]} + 1"""MAX = float("inf")dp = [0] + [MAX] * amountfor i in range(1,amount+1):dp[i] = min([dp[i-c] if i-c >=0 else MAX for c in coins]) + 1return [dp[amount],-1][dp[amount]==MAX] 7、Leetcode-198-打家劫舍 你是一個專業的小偷,計劃偷竊沿街的房屋。每間房內都藏有一定的現金,影響你偷竊的唯一制約因素就是相鄰的房屋裝有相互連通的防盜系統,如果兩間相鄰的房屋在同一晚上被小偷闖入,系統會自動報警。 給定一個代表每個房屋存放金額的非負整數數組,計算你在不觸動警報裝置的情況下,能夠偷竊到的最高金額。 示例 1: 輸入: [1,2,3,1] 輸出: 4 解釋: 偷竊 1 號房屋 (金額 = 1) ,然后偷竊 3 號房屋 (金額 = 3)。偷竊到的最高金額 = 1 + 3 = 4 。class Solution:def rob(self, nums: List[int]) -> int:cur,pre = 0,0for num in nums:cur,pre = max(pre + num, cur),curreturn cur 8、Leetcode-213-打家劫舍-II 你是一個專業的小偷,計劃偷竊沿街的房屋,每間房內都藏有一定的現金。這個地方所有的房屋都圍成一圈,這意味著第一個房屋和最后一個房屋是緊挨著的。同時,相鄰的房屋裝有相互連通的防盜系統,如果兩間相鄰的房屋在同一晚上被小偷闖入,系統會自動報警。 給定一個代表每個房屋存放金額的非負整數數組,計算你在不觸動警報裝置的情況下,能夠偷竊到的最高金額 示例 1: 輸入: [2,3,2] 輸出: 3 解釋: 你不能先偷竊 1 號房屋(金額 = 2),然后偷竊 3 號房屋(金額 = 2), 因為他們是相鄰的。class Solution:def rob(self, nums: List[int]) -> int:def my_rob(nums):cur,pre = 0,0for num in nums:pre,cur = cur,max(pre+num,cur)return curreturn max(my_rob(nums[:-1]),my_rob(nums[1:])) if len(nums)!=1 else nums[0] 動態規劃解決股票系列問題 狀態轉移框架; base case: dp[-1][k][0] = dp[i][0][0] = 0 dp[-1][k][1] = dp[i][0][1] = -float("inf") 狀態轉移方程: dp[i][k][0] = max(dp[i-1][k][0],dp[i-1][k][1] + prices[i]) dp[i][k][1] = max(dp[i-1][k][1],dp[i-1][k-1][0] - prices[i])case-1(k=1的情況): Leetcode_121_買賣股票的最佳時機 給定一個數組,它的第 i 個元素是一支給定股票第 i 天的價格。 如果你最多只允許完成一筆交易(即買入和賣出一支股票),設計一個算法來計算你所能獲取的最大利潤。 注意你不能在買入股票前賣出股票。示例 1: 輸入: [7,1,5,3,6,4] 輸出: 5 解釋: 在第 2 天(股票價格 = 1)的時候買入,在第 5 天(股票價格 = 6)的時候賣出,最大利潤 = 6-1 = 5 。注意利潤不能是 7-1 = 6, 因為賣出價格需要大于買入價格。class Solution:def maxProfit(self, prices: List[int]) -> int:dp_i_0,dp_i_1 = 0,float("-inf")for i in range(len(prices)):dp_i_0 = max(dp_i_0,dp_i_1 + prices[i])dp_i_1 = max(dp_i_1,-prices[i])return dp_i_0case_2(k=正無窮的情況):Leetcode_122_買賣股票的最佳時機II 給定一個數組,它的第 i 個元素是一支給定股票第 i 天的價格。 設計一個算法來計算你所能獲取的最大利潤。你可以盡可能地完成更多的交易(多次買賣一支股票)。 注意:你不能同時參與多筆交易(你必須在再次購買前出售掉之前的股票)。 示例 1: 輸入: [7,1,5,3,6,4] 輸出: 7 解釋: 在第 2 天(股票價格 = 1)的時候買入,在第 3 天(股票價格 = 5)的時候賣出, 這筆交易所能獲得利潤 = 5-1 = 4 。隨后,在第 4 天(股票價格 = 3)的時候買入,在第 5 天(股票價格 = 6)的時候賣出, 這筆交易所能獲得利潤 = 6-3 = 3 。分析: 在k=正無窮的情況下,上述狀態轉移方程 dp[i][k][0] = max(dp[i-1][k][0],dp[i-1][k][1] + prices[i]) dp[i][k][1] = max(dp[i-1][k][1],dp[i-1][k-1][0] - prices[i]) 轉化為 dp[i][k][0] = max(dp[i-1][k][0],dp[i-1][k][1] + prices[i]) dp[i][k][1] = max(dp[i-1][k][1],dp[i-1][k][0] - prices[i]) ==> dp[i][0] = max(dp[i-1][0],dp[i-1][1] + prices[i]) dp[i][1] = max(dp[i-1][1],dp[i-1][0] - prices[i]) code:class Solution:def maxProfit(self, prices: List[int]) -> int:dp_i_0,dp_i_1 = 0,-float("inf")for i in range(len(prices)):temp = dp_i_0dp_i_0 = max(dp_i_0,dp_i_1 + prices[i])dp_i_1 = max(dp_i_1,temp - prices[i])return dp_i_0case_3(添加手續費):Leetcode_714_買賣股票最佳時機含手續費 給定一個整數數組 prices,其中第 i 個元素代表了第 i 天的股票價格 ;非負整數 fee 代表了交易股票的手續費用。 你可以無限次地完成交易,但是你每次交易都需要付手續費。如果你已經購買了一個股票,在賣出它之前你就不能再繼續購買股票了。 返回獲得利潤的最大值。 示例 1: 輸入: prices = [1, 3, 2, 8, 4, 9], fee = 2 輸出: 8 解釋: 能夠達到的最大利潤: 在此處買入 prices[0] = 1 在此處賣出 prices[3] = 8 在此處買入 prices[4] = 4 在此處賣出 prices[5] = 9 總利潤: ((8 - 1) - 2) + ((9 - 4) - 2) = 8.class Solution:def maxProfit(self, prices: List[int], fee: int) -> int:n = len(prices)dp_i_0,dp_i_1 = 0,-float("inf")for price in prices:item = dp_i_0dp_i_0 = max(dp_i_0,dp_i_1+price)dp_i_1 = max(dp_i_1,dp_i_0-price-fee)return dp_i_0case_4(隔一天才能購買):Leetcode_309_最佳買賣股票時機含冷凍期 給定一個整數數組,其中第 i 個元素代表了第 i 天的股票價格 。 設計一個算法計算出最大利潤。在滿足以下約束條件下,你可以盡可能地完成更多的交易(多次買賣一支股票): 你不能同時參與多筆交易(你必須在再次購買前出售掉之前的股票)。 賣出股票后,你無法在第二天買入股票 (即冷凍期為 1 天)。 示例: 輸入: [1,2,3,0,2] 輸出: 3 解釋: 對應的交易狀態為: [買入, 賣出, 冷凍期, 買入, 賣出]思路: 狀態轉移方程: dp[i][0] = max(dp[i-1][0],dp[i-1][1] + prices[i]) dp[i][1] = max(dp[i-1][1],dp[i-2][0] - prices[i]) 注:i天購買時,從i-2狀態轉移 class Solution:def maxProfit(self, prices: List[int]) -> int:n = len(prices)dp_i_0,dp_i_1,da_pre = 0,float("-inf"),0for i in range(n):temp = dp_i_0dp_i_0 = max(dp_i_0,dp_i_1 + prices[i])dp_i_1 = max(dp_i_1,da_pre - prices[i])da_pre = tempreturn dp_i_0case_5(k=2情況下):leetcode_123_買賣股票的最佳時機III 給定一個數組,它的第 i 個元素是一支給定的股票在第 i 天的價格。 設計一個算法來計算你所能獲取的最大利潤。你最多可以完成 兩筆 交易。 注意: 你不能同時參與多筆交易(你必須在再次購買前出售掉之前的股票)。示例 1: 輸入: [3,3,5,0,0,3,1,4] 輸出: 6 解釋: 在第 4 天(股票價格 = 0)的時候買入,在第 6 天(股票價格 = 3)的時候賣出,這筆交易所能獲得利潤 = 3-0 = 3 。隨后,在第 7 天(股票價格 = 1)的時候買入,在第 8 天 (股票價格 = 4)的時候賣出,這筆交易所能獲得利潤 = 4-1 = 3 。k = 1,2,狀態轉移方程: dp[i][k][0] = max(dp[i-1][k][0],dp[i-1][k][1] + prices[i]) dp[i][k][1] = max(dp[i-1][k][1],dp[i-1][k-1][0] - prices[i]) => p[i][1][0] = max(dp[i-1][1][0],dp[i-1][1][1] + prices[i]) dp[i][1][1] = max(dp[i-1][1][1],dp[i-1][0][0] - prices[i]) p[i][2][0] = max(dp[i-1][2][0],dp[i-1][2][1] + prices[i]) dp[i][2][1] = max(dp[i-1][2][1],dp[i-1][1][0] - prices[i])class Solution:def maxProfit(self, prices: List[int]) -> int:dp_i10,dp_i11,dp_i20,dp_i21 = 0,-float("inf"),0,-float('inf')for price in prices:dp_i10 = max(dp_i10,dp_i11 + price)dp_i11 = max(dp_i11,-price)dp_i20 = max(dp_i20,dp_i21 + price)dp_i21 = max(dp_i21,dp_i10 - price)return dp_i20

    ?

    總結

    以上是生活随笔為你收集整理的Leetcode-一篇帖子就够啦的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    性色av无码免费一区二区三区 | 自拍偷自拍亚洲精品10p | 高潮毛片无遮挡高清免费视频 | 粗大的内捧猛烈进出视频 | 国产人妻精品一区二区三区 | 亚洲精品中文字幕乱码 | 激情内射亚州一区二区三区爱妻 | 亚洲国产精品久久人人爱 | 自拍偷自拍亚洲精品10p | 国产高清不卡无码视频 | 精品国产麻豆免费人成网站 | 亚洲中文字幕在线观看 | 亚洲中文字幕av在天堂 | aⅴ亚洲 日韩 色 图网站 播放 | 国产极品视觉盛宴 | 国内精品久久久久久中文字幕 | 日产精品高潮呻吟av久久 | 免费男性肉肉影院 | 国产人妻精品一区二区三区不卡 | 水蜜桃色314在线观看 | 国产偷抇久久精品a片69 | v一区无码内射国产 | a在线观看免费网站大全 | 曰韩无码二三区中文字幕 | 爽爽影院免费观看 | 亚洲日韩一区二区 | 一二三四在线观看免费视频 | 曰韩少妇内射免费播放 | yw尤物av无码国产在线观看 | 一本一道久久综合久久 | 日韩亚洲欧美中文高清在线 | 四十如虎的丰满熟妇啪啪 | 亚洲熟妇色xxxxx亚洲 | 俄罗斯老熟妇色xxxx | 黑人巨大精品欧美黑寡妇 | 国产精品久久久久久亚洲影视内衣 | 国产精品嫩草久久久久 | 女高中生第一次破苞av | 日韩欧美中文字幕在线三区 | 福利一区二区三区视频在线观看 | 成年美女黄网站色大免费视频 | 日韩av无码一区二区三区不卡 | 色诱久久久久综合网ywww | 久久天天躁狠狠躁夜夜免费观看 | 亚洲大尺度无码无码专区 | 亚洲国产欧美在线成人 | 欧洲vodafone精品性 | 国产无遮挡又黄又爽免费视频 | 麻豆md0077饥渴少妇 | 亚洲中文无码av永久不收费 | 午夜性刺激在线视频免费 | 亚洲色成人中文字幕网站 | 久久精品国产99精品亚洲 | 我要看www免费看插插视频 | 国产精品18久久久久久麻辣 | 久久伊人色av天堂九九小黄鸭 | 亚洲国产精品无码久久久久高潮 | 欧美精品免费观看二区 | 欧美成人高清在线播放 | 国产成人无码区免费内射一片色欲 | 中文字幕人妻无码一区二区三区 | 内射白嫩少妇超碰 | 蜜桃av抽搐高潮一区二区 | 亚洲熟妇色xxxxx欧美老妇y | 精品人妻人人做人人爽夜夜爽 | 搡女人真爽免费视频大全 | 中文毛片无遮挡高清免费 | v一区无码内射国产 | 国产精品久久久久久久影院 | 7777奇米四色成人眼影 | 国产精品久久久久久无码 | 无码国产色欲xxxxx视频 | www成人国产高清内射 | 国产美女精品一区二区三区 | 国产精品亚洲а∨无码播放麻豆 | 成年女人永久免费看片 | 亚洲精品国偷拍自产在线麻豆 | 久久久久久亚洲精品a片成人 | 欧美性生交xxxxx久久久 | 久久精品国产一区二区三区 | 欧美人与动性行为视频 | 国产欧美亚洲精品a | 国产两女互慰高潮视频在线观看 | 亚洲乱码国产乱码精品精 | 国产美女精品一区二区三区 | 欧美人与牲动交xxxx | 欧美三级a做爰在线观看 | 18精品久久久无码午夜福利 | 人人爽人人爽人人片av亚洲 | 亚洲精品美女久久久久久久 | 少妇高潮喷潮久久久影院 | 成人欧美一区二区三区黑人 | 在线成人www免费观看视频 | 亚洲色大成网站www国产 | 国产激情综合五月久久 | 精品无人区无码乱码毛片国产 | 亚洲另类伦春色综合小说 | 亚洲精品一区二区三区大桥未久 | 亚洲精品久久久久久一区二区 | 欧美日韩一区二区三区自拍 | 一本大道久久东京热无码av | 无码福利日韩神码福利片 | 亚洲の无码国产の无码影院 | 亚洲小说图区综合在线 | 丰满妇女强制高潮18xxxx | 欧美xxxxx精品 | 久久久久久国产精品无码下载 | 99国产精品白浆在线观看免费 | 又粗又大又硬又长又爽 | 日韩av激情在线观看 | 日韩av无码中文无码电影 | 999久久久国产精品消防器材 | 国产香蕉尹人综合在线观看 | 成人动漫在线观看 | 亚洲自偷精品视频自拍 | 免费国产成人高清在线观看网站 | 丰满肥臀大屁股熟妇激情视频 | 亚洲欧美国产精品久久 | 内射白嫩少妇超碰 | 老子影院午夜精品无码 | 亚洲另类伦春色综合小说 | 中文字幕乱妇无码av在线 | 精品aⅴ一区二区三区 | 日本大香伊一区二区三区 | 3d动漫精品啪啪一区二区中 | 日本大乳高潮视频在线观看 | 免费无码的av片在线观看 | 亚洲欧美日韩成人高清在线一区 | 人人妻人人澡人人爽人人精品浪潮 | 亚洲精品国产精品乱码不卡 | 亚洲日本va午夜在线电影 | 性生交片免费无码看人 | 高清国产亚洲精品自在久久 | 精品久久久久香蕉网 | 国产成人无码区免费内射一片色欲 | 成熟妇人a片免费看网站 | 亚洲精品一区二区三区在线观看 | 老太婆性杂交欧美肥老太 | 国产精品18久久久久久麻辣 | 撕开奶罩揉吮奶头视频 | 任你躁国产自任一区二区三区 | 无码免费一区二区三区 | √8天堂资源地址中文在线 | 久久国产自偷自偷免费一区调 | 久久久亚洲欧洲日产国码αv | 日韩av激情在线观看 | 国产精品怡红院永久免费 | 麻豆精品国产精华精华液好用吗 | 亚洲精品国产精品乱码不卡 | 国产疯狂伦交大片 | 亚洲а∨天堂久久精品2021 | 日日麻批免费40分钟无码 | 99久久精品无码一区二区毛片 | 天天躁日日躁狠狠躁免费麻豆 | 午夜男女很黄的视频 | 国产亚洲美女精品久久久2020 | 九一九色国产 | 精品国偷自产在线 | 1000部夫妻午夜免费 | 久久久久成人精品免费播放动漫 | 久久国产自偷自偷免费一区调 | 日日天日日夜日日摸 | 黑人巨大精品欧美一区二区 | 日韩人妻无码中文字幕视频 | 伊人久久大香线蕉亚洲 | 人人妻人人澡人人爽欧美一区九九 | 亚洲色偷偷偷综合网 | 一本精品99久久精品77 | 亚洲精品中文字幕久久久久 | 美女张开腿让人桶 | 九九综合va免费看 | 欧美国产亚洲日韩在线二区 | 亚洲精品成人av在线 | 中文精品无码中文字幕无码专区 | 国产无遮挡又黄又爽免费视频 | 蜜臀av在线播放 久久综合激激的五月天 | 日韩精品乱码av一区二区 | 天天拍夜夜添久久精品大 | 免费人成在线视频无码 | 成人无码视频免费播放 | 久久久婷婷五月亚洲97号色 | 久久精品女人的天堂av | 国产精品久免费的黄网站 | 日本乱人伦片中文三区 | 无套内谢的新婚少妇国语播放 | 在线a亚洲视频播放在线观看 | 国产精品福利视频导航 | 久久精品无码一区二区三区 | 中文字幕精品av一区二区五区 | 欧美野外疯狂做受xxxx高潮 | 欧美日本精品一区二区三区 | 日产国产精品亚洲系列 | 丰满护士巨好爽好大乳 | 女人被男人爽到呻吟的视频 | a片在线免费观看 | 久久综合香蕉国产蜜臀av | 国产又爽又黄又刺激的视频 | 国产艳妇av在线观看果冻传媒 | 麻豆av传媒蜜桃天美传媒 | 国产无av码在线观看 | 激情内射日本一区二区三区 | 久久久久免费看成人影片 | 国产乱人伦偷精品视频 | 4hu四虎永久在线观看 | 亚洲日韩一区二区 | 丝袜 中出 制服 人妻 美腿 | 全球成人中文在线 | 东北女人啪啪对白 | 国产小呦泬泬99精品 | 我要看www免费看插插视频 | 在线欧美精品一区二区三区 | 在教室伦流澡到高潮hnp视频 | 影音先锋中文字幕无码 | 欧美亚洲日韩国产人成在线播放 | 熟女俱乐部五十路六十路av | 波多野结衣 黑人 | 国产艳妇av在线观看果冻传媒 | 欧美自拍另类欧美综合图片区 | 中文字幕无码热在线视频 | 国产精品va在线播放 | 好男人社区资源 | 久久无码中文字幕免费影院蜜桃 | 特黄特色大片免费播放器图片 | 激情亚洲一区国产精品 | 成人影院yy111111在线观看 | 7777奇米四色成人眼影 | 九九热爱视频精品 | 高潮毛片无遮挡高清免费视频 | 欧美肥老太牲交大战 | 国产亲子乱弄免费视频 | 成人女人看片免费视频放人 | 一本久久a久久精品vr综合 | 双乳奶水饱满少妇呻吟 | 天海翼激烈高潮到腰振不止 | 无码播放一区二区三区 | 国产香蕉尹人视频在线 | 狂野欧美性猛xxxx乱大交 | 99久久久无码国产精品免费 | 人人妻人人澡人人爽人人精品浪潮 | 亚洲色偷偷男人的天堂 | 三上悠亚人妻中文字幕在线 | 波多野结衣一区二区三区av免费 | 亚洲成a人片在线观看无码3d | 精品久久久中文字幕人妻 | 国产人成高清在线视频99最全资源 | 无码av免费一区二区三区试看 | 澳门永久av免费网站 | 四虎国产精品一区二区 | 成人欧美一区二区三区 | 久久亚洲a片com人成 | 国产精品无码永久免费888 | 熟妇激情内射com | 久久久中文久久久无码 | 成在人线av无码免观看麻豆 | 青草视频在线播放 | 亚洲精品www久久久 | 国产99久久精品一区二区 | 澳门永久av免费网站 | 午夜理论片yy44880影院 | 亚洲色欲色欲天天天www | 亚洲色在线无码国产精品不卡 | 精品无码国产自产拍在线观看蜜 | 亚洲精品国产精品乱码不卡 | 无码人妻av免费一区二区三区 | 亚洲精品成人av在线 | 捆绑白丝粉色jk震动捧喷白浆 | 又大又硬又爽免费视频 | 蜜桃av抽搐高潮一区二区 | 国产另类ts人妖一区二区 | 国产特级毛片aaaaaaa高清 | 久久人人爽人人爽人人片av高清 | 欧美真人作爱免费视频 | 亚洲の无码国产の无码步美 | 男女猛烈xx00免费视频试看 | 亚洲中文字幕乱码av波多ji | www国产亚洲精品久久久日本 | 啦啦啦www在线观看免费视频 | 黑森林福利视频导航 | 天天做天天爱天天爽综合网 | 亚洲国精产品一二二线 | 精品国产一区二区三区av 性色 | 日韩欧美群交p片內射中文 | 西西人体www44rt大胆高清 | 日本护士毛茸茸高潮 | 人人澡人人妻人人爽人人蜜桃 | 国产性生大片免费观看性 | 欧美zoozzooz性欧美 | 久久99精品久久久久久动态图 | 国产真实乱对白精彩久久 | 久久久久久九九精品久 | 少妇高潮一区二区三区99 | 国产极品美女高潮无套在线观看 | 人妻少妇精品视频专区 | 精品偷拍一区二区三区在线看 | 欧美老妇交乱视频在线观看 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 国产精品沙发午睡系列 | 成人欧美一区二区三区黑人免费 | 中文字幕无码乱人伦 | 亚洲精品国产精品乱码不卡 | 亚洲国产日韩a在线播放 | 久久这里只有精品视频9 | 捆绑白丝粉色jk震动捧喷白浆 | 国产极品美女高潮无套在线观看 | 男女下面进入的视频免费午夜 | 中文字幕色婷婷在线视频 | 国产在线aaa片一区二区99 | 风流少妇按摩来高潮 | 免费人成网站视频在线观看 | 美女极度色诱视频国产 | 久久视频在线观看精品 | 亚洲aⅴ无码成人网站国产app | 熟妇人妻无乱码中文字幕 | 欧美人与禽zoz0性伦交 | 久久午夜夜伦鲁鲁片无码免费 | 国产猛烈高潮尖叫视频免费 | 国产精品亚洲а∨无码播放麻豆 | 亚洲热妇无码av在线播放 | 性欧美疯狂xxxxbbbb | 亚洲成a人片在线观看日本 | 亚洲无人区一区二区三区 | 精品久久8x国产免费观看 | 国产热a欧美热a在线视频 | 天天综合网天天综合色 | 内射欧美老妇wbb | 奇米影视7777久久精品 | 日本精品高清一区二区 | 熟女俱乐部五十路六十路av | 天下第一社区视频www日本 | 久久久久国色av免费观看性色 | 麻豆国产97在线 | 欧洲 | 丝袜美腿亚洲一区二区 | 天堂无码人妻精品一区二区三区 | 国产精品无码mv在线观看 | av在线亚洲欧洲日产一区二区 | 欧美喷潮久久久xxxxx | 美女毛片一区二区三区四区 | 人妻有码中文字幕在线 | 精品无码一区二区三区的天堂 | 久久国产精品精品国产色婷婷 | 国产偷国产偷精品高清尤物 | 无码免费一区二区三区 | 日韩成人一区二区三区在线观看 | 国产精品鲁鲁鲁 | 日日噜噜噜噜夜夜爽亚洲精品 | 性色欲情网站iwww九文堂 | 一本色道婷婷久久欧美 | 国产精品理论片在线观看 | 国产真人无遮挡作爱免费视频 | 国产精品久久久久久无码 | 乱码午夜-极国产极内射 | 麻豆md0077饥渴少妇 | 欧洲极品少妇 | 国产片av国语在线观看 | 大色综合色综合网站 | 又湿又紧又大又爽a视频国产 | 无码一区二区三区在线 | 77777熟女视频在线观看 а天堂中文在线官网 | 国产精华av午夜在线观看 | 精品日本一区二区三区在线观看 | 亚洲国产精品无码久久久久高潮 | 国产农村妇女高潮大叫 | 国产欧美精品一区二区三区 | 18精品久久久无码午夜福利 | 国产情侣作爱视频免费观看 | 双乳奶水饱满少妇呻吟 | 丰满人妻翻云覆雨呻吟视频 | 免费无码一区二区三区蜜桃大 | 国内揄拍国内精品人妻 | 免费观看的无遮挡av | 久久精品国产99久久6动漫 | 欧美国产日产一区二区 | 四虎国产精品免费久久 | 国产av无码专区亚洲awww | 欧美日韩综合一区二区三区 | 欧美自拍另类欧美综合图片区 | 国产激情综合五月久久 | 俄罗斯老熟妇色xxxx | 无码成人精品区在线观看 | 色 综合 欧美 亚洲 国产 | 国产成人久久精品流白浆 | 1000部夫妻午夜免费 | 午夜福利试看120秒体验区 | 久热国产vs视频在线观看 | 日本一卡二卡不卡视频查询 | 亚洲一区二区三区播放 | 国产激情综合五月久久 | 蜜桃无码一区二区三区 | 精品厕所偷拍各类美女tp嘘嘘 | 亚洲日韩av一区二区三区四区 | 亚洲成a人片在线观看无码3d | 亚洲精品久久久久中文第一幕 | 国产超碰人人爽人人做人人添 | 无码国内精品人妻少妇 | 少妇高潮一区二区三区99 | 男女超爽视频免费播放 | 亚洲中文字幕久久无码 | 久久久久se色偷偷亚洲精品av | 天天摸天天碰天天添 | 男女下面进入的视频免费午夜 | 大肉大捧一进一出好爽视频 | 曰韩无码二三区中文字幕 | 国精产品一区二区三区 | 99久久无码一区人妻 | 性做久久久久久久免费看 | 天海翼激烈高潮到腰振不止 | 欧美乱妇无乱码大黄a片 | 亚洲中文字幕在线观看 | 国产精品久久久久久久影院 | 国产亚洲精品久久久久久久 | 性色欲情网站iwww九文堂 | 亚洲 日韩 欧美 成人 在线观看 | 免费无码的av片在线观看 | 在教室伦流澡到高潮hnp视频 | 无码福利日韩神码福利片 | 久久精品99久久香蕉国产色戒 | 国产农村妇女高潮大叫 | 中文字幕人妻无码一夲道 | 97色伦图片97综合影院 | 熟妇人妻无乱码中文字幕 | 国产成人精品无码播放 | 国产高潮视频在线观看 | 性生交片免费无码看人 | 成人精品视频一区二区三区尤物 | 亚洲国产成人a精品不卡在线 | 99久久精品日本一区二区免费 | 无码av中文字幕免费放 | 最新版天堂资源中文官网 | 18无码粉嫩小泬无套在线观看 | 亚洲国产精品美女久久久久 | 天天拍夜夜添久久精品大 | 人人超人人超碰超国产 | 亚洲乱码日产精品bd | 国产农村妇女高潮大叫 | 97久久国产亚洲精品超碰热 | 国内综合精品午夜久久资源 | 香港三级日本三级妇三级 | 日本一卡二卡不卡视频查询 | 久久久久久国产精品无码下载 | 亚洲精品一区三区三区在线观看 | 色欲人妻aaaaaaa无码 | 丰满肥臀大屁股熟妇激情视频 | 亚洲色偷偷偷综合网 | 荫蒂被男人添的好舒服爽免费视频 | 欧美第一黄网免费网站 | 99久久99久久免费精品蜜桃 | 中文字幕人妻丝袜二区 | 国产午夜福利亚洲第一 | 国产香蕉97碰碰久久人人 | 人人妻人人澡人人爽人人精品浪潮 | 一个人看的视频www在线 | 成人欧美一区二区三区 | 成人免费无码大片a毛片 | 亚洲一区二区三区国产精华液 | 亚洲日本在线电影 | 国产精品沙发午睡系列 | 亚洲午夜无码久久 | 老子影院午夜精品无码 | 99久久精品日本一区二区免费 | 成人片黄网站色大片免费观看 | 欧美日韩一区二区免费视频 | 国产精品高潮呻吟av久久 | 亚洲一区二区三区播放 | 亚洲欧洲无卡二区视頻 | 成人欧美一区二区三区黑人 | 久久久久国色av免费观看性色 | 成熟人妻av无码专区 | 97夜夜澡人人双人人人喊 | 丰满岳乱妇在线观看中字无码 | 亚洲色欲色欲欲www在线 | 成人欧美一区二区三区黑人 | 丰腴饱满的极品熟妇 | 狠狠亚洲超碰狼人久久 | 18精品久久久无码午夜福利 | 国产亚洲视频中文字幕97精品 | 国产亚洲精品久久久久久久 | 成人无码视频免费播放 | 国产特级毛片aaaaaa高潮流水 | 日本大乳高潮视频在线观看 | 欧美丰满熟妇xxxx性ppx人交 | 激情亚洲一区国产精品 | 亚洲日韩乱码中文无码蜜桃臀网站 | 日本大香伊一区二区三区 | 亚洲国产av美女网站 | 久久久成人毛片无码 | 人人妻人人澡人人爽精品欧美 | 日韩人妻无码一区二区三区久久99 | 亚洲国产日韩a在线播放 | 激情综合激情五月俺也去 | 亚洲精品一区三区三区在线观看 | 波多野结衣一区二区三区av免费 | 国产人妻精品一区二区三区不卡 | 精品欧洲av无码一区二区三区 | 国产人妖乱国产精品人妖 | 免费人成在线观看网站 | 亚洲一区二区三区四区 | 九月婷婷人人澡人人添人人爽 | 中文字幕无码日韩专区 | 日本精品久久久久中文字幕 | 国产精品无码成人午夜电影 | 欧美成人午夜精品久久久 | 欧美国产日韩亚洲中文 | 亚洲va欧美va天堂v国产综合 | 无码国模国产在线观看 | a在线亚洲男人的天堂 | 欧洲vodafone精品性 | 国产亚洲精品久久久久久大师 | 蜜臀av在线播放 久久综合激激的五月天 | 小泽玛莉亚一区二区视频在线 | 欧美日韩视频无码一区二区三 | 欧美兽交xxxx×视频 | 精品无人区无码乱码毛片国产 | 天天躁日日躁狠狠躁免费麻豆 | 无码人妻av免费一区二区三区 | 大肉大捧一进一出好爽视频 | 亚洲日韩av一区二区三区中文 | 亚洲 欧美 激情 小说 另类 | 久久久成人毛片无码 | 国产两女互慰高潮视频在线观看 | 综合人妻久久一区二区精品 | 国产人妻精品一区二区三区 | 国产综合在线观看 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 人妻熟女一区 | 牲欲强的熟妇农村老妇女视频 | 国产精品va在线观看无码 | 日本丰满熟妇videos | 人妻夜夜爽天天爽三区 | 99在线 | 亚洲 | 精品人妻av区 | 国产av一区二区精品久久凹凸 | 成年美女黄网站色大免费全看 | 暴力强奷在线播放无码 | 丁香花在线影院观看在线播放 | 俄罗斯老熟妇色xxxx | 国产成人av免费观看 | 无码帝国www无码专区色综合 | 粉嫩少妇内射浓精videos | 亚洲精品一区二区三区大桥未久 | 国产在线精品一区二区三区直播 | 女人被爽到呻吟gif动态图视看 | 国产三级精品三级男人的天堂 | 日韩精品乱码av一区二区 | 日本欧美一区二区三区乱码 | 欧美亚洲国产一区二区三区 | 国产亚洲精品久久久ai换 | 亚洲精品久久久久avwww潮水 | 日本丰满护士爆乳xxxx | 欧美变态另类xxxx | 日韩欧美中文字幕公布 | 国产亚洲欧美日韩亚洲中文色 | 人妻插b视频一区二区三区 | 中文字幕无码免费久久9一区9 | 亚洲熟妇色xxxxx欧美老妇 | 高潮毛片无遮挡高清免费视频 | 国产无遮挡吃胸膜奶免费看 | 人妻无码久久精品人妻 | 少妇性l交大片欧洲热妇乱xxx | 无人区乱码一区二区三区 | 少妇的肉体aa片免费 | 欧美人与禽zoz0性伦交 | 亚洲精品一区三区三区在线观看 | 桃花色综合影院 | a在线亚洲男人的天堂 | 日韩人妻系列无码专区 | 久久久久se色偷偷亚洲精品av | 精品无码成人片一区二区98 | 少妇无码吹潮 | 久久久成人毛片无码 | 日本成熟视频免费视频 | 亚洲中文字幕成人无码 | 人人爽人人爽人人片av亚洲 | 久久无码人妻影院 | 好爽又高潮了毛片免费下载 | 久久精品女人的天堂av | 国产精品igao视频网 | 国产精品理论片在线观看 | 国产电影无码午夜在线播放 | 精品日本一区二区三区在线观看 | 欧美三级a做爰在线观看 | 久久国内精品自在自线 | 又大又硬又爽免费视频 | 午夜精品一区二区三区的区别 | 97色伦图片97综合影院 | 人人妻人人澡人人爽人人精品 | 精品国产成人一区二区三区 | 无码任你躁久久久久久久 | 亚洲国产精华液网站w | 亚洲熟妇自偷自拍另类 | 久久精品人妻少妇一区二区三区 | 午夜精品一区二区三区在线观看 | 夜先锋av资源网站 | 欧美一区二区三区 | 亚洲天堂2017无码 | 亲嘴扒胸摸屁股激烈网站 | 无码人妻黑人中文字幕 | 欧美日韩色另类综合 | 久久久久久av无码免费看大片 | 国产人妻久久精品二区三区老狼 | 人妻少妇精品视频专区 | 精品少妇爆乳无码av无码专区 | 国产乱码精品一品二品 | 97人妻精品一区二区三区 | 午夜无码区在线观看 | 一本色道久久综合亚洲精品不卡 | 精品久久久久久人妻无码中文字幕 | 最近中文2019字幕第二页 | 亚洲欧美中文字幕5发布 | 午夜性刺激在线视频免费 | 欧美日韩色另类综合 | 国产又爽又黄又刺激的视频 | 国产亚洲精品久久久闺蜜 | 久久综合给合久久狠狠狠97色 | 久久久久亚洲精品男人的天堂 | 久久久久免费精品国产 | 国产极品视觉盛宴 | 无人区乱码一区二区三区 | 无码国内精品人妻少妇 | 亚洲人成影院在线无码按摩店 | 成人无码视频免费播放 | 国内精品人妻无码久久久影院 | 久久人人爽人人爽人人片av高清 | 一本色道婷婷久久欧美 | 国产在线精品一区二区三区直播 | 日本一区二区更新不卡 | 99久久精品无码一区二区毛片 | 中文精品无码中文字幕无码专区 | 亚洲自偷精品视频自拍 | 国产在热线精品视频 | 欧美35页视频在线观看 | 亚洲日韩中文字幕在线播放 | 亚洲精品一区三区三区在线观看 | 亚洲 a v无 码免 费 成 人 a v | 一本久道久久综合狠狠爱 | 国产猛烈高潮尖叫视频免费 | 亚洲区欧美区综合区自拍区 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 免费看男女做好爽好硬视频 | 狂野欧美性猛xxxx乱大交 | 理论片87福利理论电影 | 伊人色综合久久天天小片 | 国产成人精品必看 | 一本色道婷婷久久欧美 | 国产疯狂伦交大片 | 少妇性l交大片欧洲热妇乱xxx | 麻豆国产丝袜白领秘书在线观看 | 中文字幕+乱码+中文字幕一区 | 国内精品人妻无码久久久影院 | 99国产精品白浆在线观看免费 | 99riav国产精品视频 | 日本高清一区免费中文视频 | 伊人久久大香线焦av综合影院 | 性啪啪chinese东北女人 | 亚洲精品无码国产 | 日本精品人妻无码77777 天堂一区人妻无码 | 精品无码一区二区三区爱欲 | 男人的天堂av网站 | 久久综合色之久久综合 | 久久久精品人妻久久影视 | 亚洲综合精品香蕉久久网 | 亚洲 a v无 码免 费 成 人 a v | 麻豆国产97在线 | 欧洲 | 在线天堂新版最新版在线8 | 国产又粗又硬又大爽黄老大爷视 | 精品人人妻人人澡人人爽人人 | 天堂在线观看www | 最新国产乱人伦偷精品免费网站 | 国产成人久久精品流白浆 | 亚洲中文字幕av在天堂 | 蜜桃av抽搐高潮一区二区 | 久久视频在线观看精品 | 国产精品无码成人午夜电影 | 亚洲精品国偷拍自产在线观看蜜桃 | 久久综合给合久久狠狠狠97色 | 精品人妻中文字幕有码在线 | 亚洲成av人在线观看网址 | 亚洲精品久久久久久久久久久 | 成人亚洲精品久久久久 | 波多野结衣乳巨码无在线观看 | 久久视频在线观看精品 | 领导边摸边吃奶边做爽在线观看 | 性生交大片免费看女人按摩摩 | 性欧美videos高清精品 | 99精品无人区乱码1区2区3区 | 国产色xx群视频射精 | 男女下面进入的视频免费午夜 | 麻豆果冻传媒2021精品传媒一区下载 | 鲁一鲁av2019在线 | 性欧美大战久久久久久久 | 蜜桃av抽搐高潮一区二区 | 国产又粗又硬又大爽黄老大爷视 | 亚洲综合无码久久精品综合 | 亚洲午夜福利在线观看 | 日韩av无码一区二区三区不卡 | 国产亚av手机在线观看 | 鲁一鲁av2019在线 | 国内精品人妻无码久久久影院 | 亚洲国产精品久久人人爱 | 又黄又爽又色的视频 | 内射后入在线观看一区 | 高清无码午夜福利视频 | 日本精品人妻无码77777 天堂一区人妻无码 | 内射爽无广熟女亚洲 | 欧美精品免费观看二区 | 精品无码成人片一区二区98 | 丰满人妻精品国产99aⅴ | 亚洲精品一区三区三区在线观看 | 激情爆乳一区二区三区 | 亚洲の无码国产の无码步美 | 色综合久久网 | 亚洲热妇无码av在线播放 | 婷婷五月综合激情中文字幕 | 亚洲国产精品无码一区二区三区 | 一二三四社区在线中文视频 | 久久久久久a亚洲欧洲av冫 | 久久99久久99精品中文字幕 | 久久久精品人妻久久影视 | 久久久久99精品成人片 | 久久久av男人的天堂 | 国产精品久久精品三级 | 亚洲爆乳精品无码一区二区三区 | 亚洲日韩av片在线观看 | 狂野欧美性猛交免费视频 | 国产精品亚洲综合色区韩国 | 欧美老人巨大xxxx做受 | 亚洲国产欧美国产综合一区 | 久久熟妇人妻午夜寂寞影院 | 在线观看国产午夜福利片 | 成人女人看片免费视频放人 | 国产激情无码一区二区app | 国精品人妻无码一区二区三区蜜柚 | 国产亚洲美女精品久久久2020 | 欧美亚洲国产一区二区三区 | 97久久精品无码一区二区 | 日韩精品一区二区av在线 | 亚洲色www成人永久网址 | 亚洲gv猛男gv无码男同 | 久久99久久99精品中文字幕 | 天天摸天天碰天天添 | 久久久国产精品无码免费专区 | 天天拍夜夜添久久精品大 | 国产精品99久久精品爆乳 | 爽爽影院免费观看 | 偷窥村妇洗澡毛毛多 | 午夜福利一区二区三区在线观看 | 国产美女精品一区二区三区 | 4hu四虎永久在线观看 | 国产做国产爱免费视频 | 亚洲 另类 在线 欧美 制服 | 亚洲国产av美女网站 | 欧美激情综合亚洲一二区 | 一本久道高清无码视频 | 亚洲精品国产精品乱码不卡 | 中文亚洲成a人片在线观看 | 国产特级毛片aaaaaa高潮流水 | 激情国产av做激情国产爱 | 日本在线高清不卡免费播放 | 成人无码视频免费播放 | 蜜桃视频韩日免费播放 | 亚洲欧美中文字幕5发布 | 免费无码一区二区三区蜜桃大 | 狂野欧美激情性xxxx | 久久亚洲精品中文字幕无男同 | 国产真实乱对白精彩久久 | 欧美亚洲日韩国产人成在线播放 | 在线亚洲高清揄拍自拍一品区 | 熟女体下毛毛黑森林 | 四虎永久在线精品免费网址 | 精品久久8x国产免费观看 | 综合激情五月综合激情五月激情1 | 亚洲国产精品成人久久蜜臀 | 人人妻人人澡人人爽欧美一区九九 | 精品一区二区三区无码免费视频 | 国产精品亚洲综合色区韩国 | 国产亚洲精品精品国产亚洲综合 | 国产精品美女久久久网av | 无码人妻丰满熟妇区毛片18 | ass日本丰满熟妇pics | 蜜桃视频插满18在线观看 | 欧美成人高清在线播放 | 国内精品九九久久久精品 | 国产亚洲人成在线播放 | 兔费看少妇性l交大片免费 | 九九久久精品国产免费看小说 | 欧美人与善在线com | 国产无套粉嫩白浆在线 | 又湿又紧又大又爽a视频国产 | 国产舌乚八伦偷品w中 | 老太婆性杂交欧美肥老太 | 日韩av激情在线观看 | 国产日产欧产精品精品app | 色婷婷香蕉在线一区二区 | 青青久在线视频免费观看 | 一本精品99久久精品77 | 亚洲人成网站在线播放942 | 蜜臀aⅴ国产精品久久久国产老师 | 色噜噜亚洲男人的天堂 | 欧洲熟妇色 欧美 | 鲁大师影院在线观看 | 97精品国产97久久久久久免费 | 成人性做爰aaa片免费看 | 自拍偷自拍亚洲精品10p | 亚洲毛片av日韩av无码 | 亚洲日韩一区二区三区 | 成人免费视频视频在线观看 免费 | 成人亚洲精品久久久久软件 | 久久综合网欧美色妞网 | 国产艳妇av在线观看果冻传媒 | 日本一本二本三区免费 | 无人区乱码一区二区三区 | 内射欧美老妇wbb | 欧洲熟妇精品视频 | 美女张开腿让人桶 | 亚洲综合无码一区二区三区 | 女人高潮内射99精品 | 成人无码精品1区2区3区免费看 | 国产成人人人97超碰超爽8 | 国产真人无遮挡作爱免费视频 | 欧美日韩在线亚洲综合国产人 | 亚洲午夜福利在线观看 | 中文字幕亚洲情99在线 | 麻花豆传媒剧国产免费mv在线 | 成人欧美一区二区三区黑人 | 亚洲中文无码av永久不收费 | 日日摸天天摸爽爽狠狠97 | 欧美成人高清在线播放 | 欧美性生交活xxxxxdddd | 强开小婷嫩苞又嫩又紧视频 | 亚洲精品美女久久久久久久 | 中文字幕无码日韩欧毛 | 天天拍夜夜添久久精品 | 精品一区二区三区无码免费视频 | 欧美人与物videos另类 | 精品人妻人人做人人爽 | 在线精品国产一区二区三区 | 3d动漫精品啪啪一区二区中 | yw尤物av无码国产在线观看 | 欧美 日韩 亚洲 在线 | 欧美高清在线精品一区 | 日韩亚洲欧美中文高清在线 | 久久久www成人免费毛片 | 午夜嘿嘿嘿影院 | 亚洲码国产精品高潮在线 | 婷婷五月综合缴情在线视频 | 又紧又大又爽精品一区二区 | 狠狠色丁香久久婷婷综合五月 | 国产猛烈高潮尖叫视频免费 | 亚洲欧美综合区丁香五月小说 | 国内精品久久久久久中文字幕 | 丰满少妇弄高潮了www | 国产麻豆精品一区二区三区v视界 | 亚洲日本一区二区三区在线 | 亚洲一区二区三区国产精华液 | 国产精品久久久久9999小说 | 亚洲日本在线电影 | 久久久久av无码免费网 | 小sao货水好多真紧h无码视频 | 国产精品视频免费播放 | 国产香蕉尹人综合在线观看 | 国产suv精品一区二区五 | 欧美真人作爱免费视频 | 亚洲乱码中文字幕在线 | 国产凸凹视频一区二区 | 少妇无套内谢久久久久 | 成在人线av无码免费 | 亚洲成av人在线观看网址 | 青草视频在线播放 | 无码精品人妻一区二区三区av | 国产亚洲欧美日韩亚洲中文色 | 67194成是人免费无码 | 香蕉久久久久久av成人 | 九月婷婷人人澡人人添人人爽 | 色综合久久久无码中文字幕 | 丰满护士巨好爽好大乳 | 欧美猛少妇色xxxxx | 久久天天躁狠狠躁夜夜免费观看 | 日韩少妇白浆无码系列 | 亚洲成av人片在线观看无码不卡 | 亚洲日本va中文字幕 | 国产精品沙发午睡系列 | 亚洲国产精品无码一区二区三区 | 成人免费无码大片a毛片 | 成人性做爰aaa片免费看不忠 | 国产三级久久久精品麻豆三级 | 夜夜躁日日躁狠狠久久av | 亚洲男女内射在线播放 | 伊人久久大香线蕉av一区二区 | 奇米影视7777久久精品人人爽 | 131美女爱做视频 | 夜精品a片一区二区三区无码白浆 | 清纯唯美经典一区二区 | 久9re热视频这里只有精品 | 亚洲欧美日韩综合久久久 | 曰本女人与公拘交酡免费视频 | 国产无遮挡又黄又爽又色 | 无码播放一区二区三区 | 人人妻人人澡人人爽欧美一区 | 国产精品亚洲а∨无码播放麻豆 | 日韩无码专区 | 成人一在线视频日韩国产 | 日本熟妇人妻xxxxx人hd | 国模大胆一区二区三区 | 成人亚洲精品久久久久软件 | а√天堂www在线天堂小说 | 欧美一区二区三区 | 国产在线无码精品电影网 | 国产又粗又硬又大爽黄老大爷视 | 特级做a爰片毛片免费69 | 久久国语露脸国产精品电影 | 成年美女黄网站色大免费全看 | 国産精品久久久久久久 | a在线观看免费网站大全 | 国产明星裸体无码xxxx视频 | 日韩亚洲欧美精品综合 | 亚洲欧美精品aaaaaa片 | 人人妻人人澡人人爽欧美一区九九 | 蜜桃视频韩日免费播放 | 2019午夜福利不卡片在线 | 亚洲人亚洲人成电影网站色 | 中文字幕人妻丝袜二区 | 红桃av一区二区三区在线无码av | 欧美国产日韩亚洲中文 | 日韩av无码一区二区三区 | 在线精品亚洲一区二区 | 鲁鲁鲁爽爽爽在线视频观看 | 成人动漫在线观看 | 婷婷综合久久中文字幕蜜桃三电影 | 久久亚洲日韩精品一区二区三区 | 色综合视频一区二区三区 | 亚洲精品一区二区三区在线观看 | 亚洲 a v无 码免 费 成 人 a v | 久久99精品久久久久婷婷 | 疯狂三人交性欧美 | 久久视频在线观看精品 | 国产特级毛片aaaaaa高潮流水 | 精品无码国产自产拍在线观看蜜 | 国产精品亚洲а∨无码播放麻豆 | 国产精品久久久久久亚洲影视内衣 | 久久 国产 尿 小便 嘘嘘 | 99久久久无码国产aaa精品 | 内射爽无广熟女亚洲 | 特级做a爰片毛片免费69 | 男女猛烈xx00免费视频试看 | 真人与拘做受免费视频 | 欧美黑人巨大xxxxx | 午夜肉伦伦影院 | 白嫩日本少妇做爰 | 中国女人内谢69xxxx | 亚洲日韩精品欧美一区二区 | 伊人久久婷婷五月综合97色 | 精品久久8x国产免费观看 | 亚洲午夜无码久久 | 六十路熟妇乱子伦 | 天堂在线观看www | 国产乱码精品一品二品 | 高潮毛片无遮挡高清免费视频 | 免费国产成人高清在线观看网站 | 天堂亚洲2017在线观看 | 丰满护士巨好爽好大乳 | 亚洲国产精品久久久天堂 | 国产精品对白交换视频 | 乱码午夜-极国产极内射 | 亚洲 a v无 码免 费 成 人 a v | 乱人伦人妻中文字幕无码久久网 | 成人欧美一区二区三区 | 天天av天天av天天透 | 国产熟女一区二区三区四区五区 | 久久99国产综合精品 | 日日鲁鲁鲁夜夜爽爽狠狠 | 牲欲强的熟妇农村老妇女视频 | 国内精品一区二区三区不卡 | 国产另类ts人妖一区二区 | 天堂亚洲免费视频 | 无码国产乱人伦偷精品视频 | 欧美三级a做爰在线观看 | 亚洲国产精品无码一区二区三区 | 88国产精品欧美一区二区三区 | 999久久久国产精品消防器材 | 国产精品国产自线拍免费软件 | 好爽又高潮了毛片免费下载 | 综合人妻久久一区二区精品 | 色综合久久久久综合一本到桃花网 | 成在人线av无码免费 | 中文字幕乱码亚洲无线三区 | 久久熟妇人妻午夜寂寞影院 | 国产在线精品一区二区三区直播 | 成人亚洲精品久久久久 | 国产亲子乱弄免费视频 | 国产精品毛多多水多 | 国产成人人人97超碰超爽8 | 一个人看的www免费视频在线观看 | 人妻互换免费中文字幕 | 久久久精品456亚洲影院 | 国产亚洲欧美日韩亚洲中文色 | 狠狠cao日日穞夜夜穞av | 亚洲一区av无码专区在线观看 | 国产精华av午夜在线观看 | 人人妻人人藻人人爽欧美一区 | 午夜不卡av免费 一本久久a久久精品vr综合 | 久久久久久久久888 | 丰满人妻被黑人猛烈进入 | 国产熟妇高潮叫床视频播放 | 亚洲国产日韩a在线播放 | 免费无码午夜福利片69 | 无码人妻少妇伦在线电影 | 在线观看国产午夜福利片 | 老子影院午夜精品无码 | 亚洲国产精品久久久天堂 | 国产9 9在线 | 中文 | 又大又黄又粗又爽的免费视频 | 久久综合香蕉国产蜜臀av | 久久精品一区二区三区四区 | 亚洲成a人一区二区三区 | 天堂久久天堂av色综合 | 老熟妇仑乱视频一区二区 | 国产香蕉尹人综合在线观看 | 色婷婷综合中文久久一本 | 三级4级全黄60分钟 | 国产精品久久精品三级 | 又大又紧又粉嫩18p少妇 | 亚洲一区二区观看播放 | 人人妻在人人 | 色情久久久av熟女人妻网站 | 国色天香社区在线视频 | 扒开双腿吃奶呻吟做受视频 | 久久久久久久久蜜桃 | 天天躁夜夜躁狠狠是什么心态 | 狠狠色噜噜狠狠狠狠7777米奇 | 亚洲中文字幕va福利 | 久久99精品久久久久久动态图 | 国产欧美亚洲精品a | 黑人巨大精品欧美黑寡妇 | 亚洲va中文字幕无码久久不卡 | 欧美xxxxx精品 | 一本无码人妻在中文字幕免费 | 亚洲中文字幕乱码av波多ji | 无码纯肉视频在线观看 | 激情内射日本一区二区三区 | 国产精品永久免费视频 | 国产亚洲欧美日韩亚洲中文色 | 99久久婷婷国产综合精品青草免费 | 国产偷自视频区视频 | 18禁黄网站男男禁片免费观看 | 国产成人综合色在线观看网站 | 全球成人中文在线 | 精品偷拍一区二区三区在线看 | 日韩av激情在线观看 | 国产精品福利视频导航 | 漂亮人妻洗澡被公强 日日躁 | 精品少妇爆乳无码av无码专区 | 国产一区二区三区四区五区加勒比 | 国产电影无码午夜在线播放 | 中文字幕人妻丝袜二区 | 午夜不卡av免费 一本久久a久久精品vr综合 | 中文字幕乱码中文乱码51精品 | 欧美变态另类xxxx | 国产av剧情md精品麻豆 | 十八禁视频网站在线观看 | 黑森林福利视频导航 | 少妇一晚三次一区二区三区 | 日韩欧美群交p片內射中文 | 国产av一区二区三区最新精品 | 免费网站看v片在线18禁无码 | 久久精品中文闷骚内射 | 国产午夜视频在线观看 | 内射老妇bbwx0c0ck | 国内精品久久毛片一区二区 | 日本熟妇乱子伦xxxx | 亚洲国产成人av在线观看 | 亚洲成a人一区二区三区 | 四虎国产精品免费久久 | 狂野欧美性猛xxxx乱大交 | 国产成人精品一区二区在线小狼 | 久久精品女人的天堂av | 秋霞成人午夜鲁丝一区二区三区 | 牲欲强的熟妇农村老妇女 | 在线精品国产一区二区三区 | 免费无码的av片在线观看 | 欧美一区二区三区视频在线观看 | 日韩av无码一区二区三区不卡 | 全黄性性激高免费视频 | 少妇激情av一区二区 | 四虎国产精品免费久久 | 领导边摸边吃奶边做爽在线观看 | 青青久在线视频免费观看 | 午夜精品久久久久久久 | 国产精品香蕉在线观看 | 色婷婷欧美在线播放内射 | 亚洲精品www久久久 | 国产成人一区二区三区别 | 国内少妇偷人精品视频 | 99久久人妻精品免费二区 | 综合人妻久久一区二区精品 | 国产69精品久久久久app下载 | 亚洲天堂2017无码 | 国产内射爽爽大片视频社区在线 | 波多野结衣av一区二区全免费观看 | 激情内射亚州一区二区三区爱妻 | 大乳丰满人妻中文字幕日本 | 欧洲欧美人成视频在线 | 日本饥渴人妻欲求不满 | 亚洲综合色区中文字幕 | 色欲久久久天天天综合网精品 | 白嫩日本少妇做爰 | 色欲久久久天天天综合网精品 | 国产一区二区三区影院 | 亚洲精品一区二区三区婷婷月 | 亚洲成av人在线观看网址 | 特大黑人娇小亚洲女 | 特大黑人娇小亚洲女 | 十八禁视频网站在线观看 | 亚洲成av人影院在线观看 | 欧美精品国产综合久久 | 国产成人人人97超碰超爽8 | 成熟女人特级毛片www免费 | 亚洲日韩av一区二区三区中文 | 日本一卡2卡3卡四卡精品网站 | 西西人体www44rt大胆高清 | 2020最新国产自产精品 | 人妻中文无码久热丝袜 | 精品国精品国产自在久国产87 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 国产成人无码专区 | 久热国产vs视频在线观看 | 激情五月综合色婷婷一区二区 | 色婷婷av一区二区三区之红樱桃 | 婷婷丁香五月天综合东京热 | 日本护士xxxxhd少妇 | 亚洲中文字幕乱码av波多ji | 男女下面进入的视频免费午夜 | 久久久久久av无码免费看大片 | 欧美野外疯狂做受xxxx高潮 | 色综合天天综合狠狠爱 | 性色欲情网站iwww九文堂 | 日本熟妇浓毛 | 亚洲欧洲无卡二区视頻 | 中文字幕人妻无码一区二区三区 | 成人欧美一区二区三区黑人 | 国产精品亚洲а∨无码播放麻豆 | 国产两女互慰高潮视频在线观看 | 成人欧美一区二区三区 | 最近中文2019字幕第二页 | 色一情一乱一伦一区二区三欧美 | 狠狠色噜噜狠狠狠狠7777米奇 | 无码纯肉视频在线观看 | 亚洲国产精品毛片av不卡在线 | 日本熟妇大屁股人妻 | 少妇被粗大的猛进出69影院 | 1000部啪啪未满十八勿入下载 | 九九在线中文字幕无码 | 国产午夜手机精彩视频 | 免费人成网站视频在线观看 | 一本久久a久久精品亚洲 | 成人无码精品一区二区三区 | 久久久久久久女国产乱让韩 | 国产精品-区区久久久狼 | 人妻夜夜爽天天爽三区 | 99久久精品日本一区二区免费 | 国产乱子伦视频在线播放 | 蜜桃视频韩日免费播放 | 亚洲精品久久久久avwww潮水 | 夜夜高潮次次欢爽av女 | 特级做a爰片毛片免费69 | 国产精品自产拍在线观看 | 色婷婷久久一区二区三区麻豆 | 久久精品国产日本波多野结衣 | 国产疯狂伦交大片 | 无人区乱码一区二区三区 | 国产成人精品视频ⅴa片软件竹菊 | 国产无遮挡又黄又爽免费视频 | 国内综合精品午夜久久资源 | 国产成人无码午夜视频在线观看 | 欧美人与动性行为视频 | 国产精品久久久久久久9999 | 高中生自慰www网站 | 精品一区二区三区波多野结衣 | 国产激情无码一区二区 | 国产亚洲精品久久久ai换 | 久久久久久a亚洲欧洲av冫 | 欧美性生交xxxxx久久久 | 装睡被陌生人摸出水好爽 | 国产无遮挡又黄又爽又色 | 日日碰狠狠丁香久燥 | 亚洲国产欧美在线成人 | 性啪啪chinese东北女人 | 欧美国产亚洲日韩在线二区 | 中文字幕 亚洲精品 第1页 | 日本www一道久久久免费榴莲 | 学生妹亚洲一区二区 | 又黄又爽又色的视频 | 亚洲色欲色欲欲www在线 | 欧美性生交xxxxx久久久 | 丰腴饱满的极品熟妇 | 久久这里只有精品视频9 | 国产精品久久国产精品99 | 久久人人爽人人爽人人片av高清 | 日日鲁鲁鲁夜夜爽爽狠狠 | 精品无码国产自产拍在线观看蜜 | 久久久久久久人妻无码中文字幕爆 | 中文字幕无码免费久久99 | 18精品久久久无码午夜福利 | 真人与拘做受免费视频一 | 一区二区三区乱码在线 | 欧洲 | 精品无码av一区二区三区 | 国产精品对白交换视频 | 婷婷五月综合缴情在线视频 | 亚洲综合在线一区二区三区 | 国产肉丝袜在线观看 | 水蜜桃色314在线观看 | 国产无套粉嫩白浆在线 | 精品无码成人片一区二区98 | 免费看男女做好爽好硬视频 | 日韩视频 中文字幕 视频一区 | 久久精品无码一区二区三区 | 亚洲欧美精品aaaaaa片 | 久久综合香蕉国产蜜臀av | 亚洲综合伊人久久大杳蕉 | 无码午夜成人1000部免费视频 | 久久综合狠狠综合久久综合88 | 性欧美熟妇videofreesex | 亚洲日韩乱码中文无码蜜桃臀网站 | 国产成人亚洲综合无码 | 在线观看免费人成视频 | 精品无人区无码乱码毛片国产 | 色老头在线一区二区三区 | 亚洲精品一区国产 | 国产 精品 自在自线 | 国产免费无码一区二区视频 | 激情亚洲一区国产精品 | 亚洲精品成a人在线观看 | 日韩人妻少妇一区二区三区 | 欧美性生交活xxxxxdddd | 国产精品a成v人在线播放 | 亚洲精品中文字幕 | 日韩欧美成人免费观看 | 日日摸夜夜摸狠狠摸婷婷 | 国产av久久久久精东av | 亚洲成色www久久网站 | 天堂а√在线地址中文在线 | 国产无套粉嫩白浆在线 | 久久天天躁狠狠躁夜夜免费观看 | 天堂在线观看www | 天堂在线观看www | 99久久99久久免费精品蜜桃 | 少妇无码av无码专区在线观看 | 女高中生第一次破苞av | 国产精品鲁鲁鲁 | 沈阳熟女露脸对白视频 | 日韩人妻无码中文字幕视频 | 女人被男人爽到呻吟的视频 | 国产人妖乱国产精品人妖 | 色综合久久久无码网中文 | 日本免费一区二区三区最新 | 国内精品久久久久久中文字幕 | 国产人成高清在线视频99最全资源 | 一本一道久久综合久久 | 久久久久人妻一区精品色欧美 | 精品一二三区久久aaa片 | 日韩av激情在线观看 | 亚洲一区二区三区 | 欧美大屁股xxxxhd黑色 | 精品国精品国产自在久国产87 | 欧美人与牲动交xxxx | 亚洲中文字幕乱码av波多ji | 亚洲爆乳精品无码一区二区三区 | 少妇无套内谢久久久久 | 成人无码视频在线观看网站 | 欧美人与禽zoz0性伦交 | 俄罗斯老熟妇色xxxx | 精品国产一区二区三区av 性色 | 在线成人www免费观看视频 | 亚洲日韩av一区二区三区四区 | 午夜丰满少妇性开放视频 | 久久久精品欧美一区二区免费 | 久久99热只有频精品8 | 亚洲乱码日产精品bd | 99久久99久久免费精品蜜桃 | 国产特级毛片aaaaaa高潮流水 | 欧美xxxxx精品 | 最近免费中文字幕中文高清百度 | 日韩精品a片一区二区三区妖精 | 熟女少妇在线视频播放 | 亚洲熟妇色xxxxx欧美老妇y | 精品国产精品久久一区免费式 | 人妻少妇精品无码专区二区 | 奇米影视888欧美在线观看 | 一本大道久久东京热无码av | 国产人妻人伦精品1国产丝袜 | 国产精品无套呻吟在线 | 亚洲中文字幕成人无码 | 久久久久人妻一区精品色欧美 | 国产深夜福利视频在线 | 亚洲成色www久久网站 | 一区二区三区乱码在线 | 欧洲 | 国産精品久久久久久久 | 少妇性荡欲午夜性开放视频剧场 | 国产精品理论片在线观看 | 麻豆果冻传媒2021精品传媒一区下载 | 国产成人无码a区在线观看视频app | 国产高清不卡无码视频 | 色综合久久久久综合一本到桃花网 | 丝袜美腿亚洲一区二区 | 亚洲国产欧美日韩精品一区二区三区 | 日本一本二本三区免费 | 青春草在线视频免费观看 | 国产精品怡红院永久免费 | 日本爽爽爽爽爽爽在线观看免 | 欧美国产日产一区二区 | 水蜜桃亚洲一二三四在线 | 福利一区二区三区视频在线观看 | 亚洲成色www久久网站 | 欧美 日韩 亚洲 在线 | 樱花草在线播放免费中文 | 国产婷婷色一区二区三区在线 | 亚洲成a人一区二区三区 | 亚洲国产成人av在线观看 | 国产成人无码av片在线观看不卡 | 狠狠色丁香久久婷婷综合五月 | 未满小14洗澡无码视频网站 | 在线观看欧美一区二区三区 | 中文亚洲成a人片在线观看 | 久久综合色之久久综合 | 人人澡人人妻人人爽人人蜜桃 | 巨爆乳无码视频在线观看 | 天堂а√在线地址中文在线 | 色欲久久久天天天综合网精品 | 一本色道久久综合狠狠躁 | 欧美日韩视频无码一区二区三 | 久久久久久亚洲精品a片成人 | 亚洲狠狠婷婷综合久久 | 乱中年女人伦av三区 | 久久午夜夜伦鲁鲁片无码免费 | 一二三四社区在线中文视频 | 久久久久久九九精品久 | 噜噜噜亚洲色成人网站 | 国产精品高潮呻吟av久久4虎 | 无码av最新清无码专区吞精 | 午夜免费福利小电影 | 樱花草在线播放免费中文 | 久久精品丝袜高跟鞋 | 精品国产一区二区三区av 性色 | 老子影院午夜精品无码 | 四虎影视成人永久免费观看视频 | 女人被爽到呻吟gif动态图视看 | 女人和拘做爰正片视频 | 少妇太爽了在线观看 | 波多野结衣av一区二区全免费观看 | 亚洲国产综合无码一区 | 女人被男人爽到呻吟的视频 | 亚洲国产一区二区三区在线观看 | 中文字幕无线码 | 日本一本二本三区免费 | 亚洲国产精品久久久久久 | 日日橹狠狠爱欧美视频 | 国内揄拍国内精品人妻 | 欧美性生交活xxxxxdddd | 日本乱偷人妻中文字幕 | 日本熟妇大屁股人妻 | 国产精品无套呻吟在线 | 2019午夜福利不卡片在线 | 成人影院yy111111在线观看 | 国产两女互慰高潮视频在线观看 | 日本乱人伦片中文三区 | 中文字幕av日韩精品一区二区 | 日韩无码专区 | 亚洲精品国产精品乱码视色 | 在线精品国产一区二区三区 | 欧美成人午夜精品久久久 | 55夜色66夜色国产精品视频 | 久久综合九色综合欧美狠狠 | 日产精品99久久久久久 | 日本一卡2卡3卡四卡精品网站 | 亚洲中文字幕无码中文字在线 | 亚洲男女内射在线播放 | 亚洲伊人久久精品影院 | 3d动漫精品啪啪一区二区中 | 亚洲色欲色欲天天天www | 熟女体下毛毛黑森林 | 丰满人妻翻云覆雨呻吟视频 | 国产色精品久久人妻 | 99国产精品白浆在线观看免费 | 精品无码国产自产拍在线观看蜜 | 亚洲乱码国产乱码精品精 | 色一情一乱一伦一视频免费看 | 久久婷婷五月综合色国产香蕉 | 久久久久久亚洲精品a片成人 | 精品无码国产一区二区三区av | 亚洲色偷偷偷综合网 | 日韩av激情在线观看 | 国产成人综合在线女婷五月99播放 | 日韩成人一区二区三区在线观看 | 精品国产aⅴ无码一区二区 | 无码人妻av免费一区二区三区 | 国产精品丝袜黑色高跟鞋 | 久久久久se色偷偷亚洲精品av | 国产成人午夜福利在线播放 | 88国产精品欧美一区二区三区 | 人妻尝试又大又粗久久 | 欧美zoozzooz性欧美 | 久久精品视频在线看15 | 美女张开腿让人桶 | 日韩少妇白浆无码系列 | 久久久国产精品无码免费专区 | 欧美怡红院免费全部视频 | 亚洲一区二区三区 | 成人精品视频一区二区三区尤物 | 日韩少妇内射免费播放 | 亚洲综合在线一区二区三区 | 美女张开腿让人桶 | 国产高清不卡无码视频 | 欧美丰满少妇xxxx性 | 久久五月精品中文字幕 | 国産精品久久久久久久 | 亚洲成a人一区二区三区 | 国产小呦泬泬99精品 | 国产xxx69麻豆国语对白 | 国产97色在线 | 免 | 亚洲无人区一区二区三区 | 亚洲小说图区综合在线 | 亚洲精品国产第一综合99久久 | 亚洲 欧美 激情 小说 另类 | 99久久久无码国产aaa精品 | 少妇无码一区二区二三区 | 成人免费视频一区二区 | 亚洲性无码av中文字幕 | 天堂亚洲2017在线观看 | 无码乱肉视频免费大全合集 | 久久熟妇人妻午夜寂寞影院 | 欧美性猛交内射兽交老熟妇 | aⅴ亚洲 日韩 色 图网站 播放 | 国产一精品一av一免费 | 免费无码一区二区三区蜜桃大 | 亚洲精品国偷拍自产在线观看蜜桃 | 日韩亚洲欧美精品综合 | 久久精品中文字幕大胸 | 性色av无码免费一区二区三区 | 欧美刺激性大交 | 精品夜夜澡人妻无码av蜜桃 | 中文毛片无遮挡高清免费 | 久久精品国产亚洲精品 | 少妇无套内谢久久久久 | 国产成人精品一区二区在线小狼 | 在线看片无码永久免费视频 | 高潮毛片无遮挡高清免费 | 性欧美疯狂xxxxbbbb | 日日天干夜夜狠狠爱 | 中文字幕日韩精品一区二区三区 | 日日摸夜夜摸狠狠摸婷婷 | 亚洲欧美精品伊人久久 | 色综合久久88色综合天天 | 免费网站看v片在线18禁无码 | 中文无码精品a∨在线观看不卡 | 99久久精品无码一区二区毛片 | 亚洲色欲久久久综合网东京热 | 岛国片人妻三上悠亚 | 国内精品人妻无码久久久影院蜜桃 | 国产美女精品一区二区三区 | 欧美人与物videos另类 | 亚洲精品国产品国语在线观看 | 久久亚洲精品中文字幕无男同 | 少妇人妻偷人精品无码视频 | 欧美三级不卡在线观看 | 欧洲极品少妇 | 欧美大屁股xxxxhd黑色 | 免费无码午夜福利片69 | 丁香啪啪综合成人亚洲 | 亚洲男人av香蕉爽爽爽爽 | 久久99精品久久久久久 | 亚洲精品久久久久avwww潮水 | 荫蒂添的好舒服视频囗交 | 亚洲熟悉妇女xxx妇女av | 性色欲情网站iwww九文堂 | 亚洲欧美国产精品专区久久 | 红桃av一区二区三区在线无码av | 国产suv精品一区二区五 | 成人亚洲精品久久久久软件 | 131美女爱做视频 | 久久午夜夜伦鲁鲁片无码免费 | 国产av久久久久精东av | 国产办公室秘书无码精品99 | 欧美 日韩 人妻 高清 中文 | 日产精品99久久久久久 | a片在线免费观看 | 欧美 亚洲 国产 另类 | 国产精品资源一区二区 | 中文字幕无码热在线视频 | 97久久精品无码一区二区 | 久久视频在线观看精品 | 亚洲国产欧美在线成人 | 国产乱子伦视频在线播放 | aa片在线观看视频在线播放 | 色狠狠av一区二区三区 | 精品欧美一区二区三区久久久 | 国产精品a成v人在线播放 | 亚洲人成网站在线播放942 | 午夜丰满少妇性开放视频 | 国产欧美精品一区二区三区 | 狠狠躁日日躁夜夜躁2020 | 精品久久久久久人妻无码中文字幕 | 在线看片无码永久免费视频 | 亚洲综合色区中文字幕 | 国产无遮挡又黄又爽又色 | 免费播放一区二区三区 | 久久国产精品偷任你爽任你 | 女人高潮内射99精品 | 亚洲人成网站色7799 | 爱做久久久久久 | 77777熟女视频在线观看 а天堂中文在线官网 | 国产一区二区三区四区五区加勒比 | 中文久久乱码一区二区 | 中文字幕av无码一区二区三区电影 | 亚洲熟悉妇女xxx妇女av | 午夜精品久久久久久久久 | 亚洲s色大片在线观看 | аⅴ资源天堂资源库在线 | 99精品无人区乱码1区2区3区 | 特大黑人娇小亚洲女 | 爽爽影院免费观看 | 帮老师解开蕾丝奶罩吸乳网站 | 欧洲美熟女乱又伦 | 亚洲理论电影在线观看 | 国产乱人无码伦av在线a | 亚洲中文字幕久久无码 | 久久www免费人成人片 | 狂野欧美性猛xxxx乱大交 | 亚洲欧美综合区丁香五月小说 | 欧美性生交活xxxxxdddd | 国产97人人超碰caoprom | 国产亚洲精品久久久ai换 | 女人色极品影院 | 亚洲精品一区二区三区大桥未久 | 国产精品久久国产精品99 | 亚洲精品成人福利网站 | 99精品视频在线观看免费 | 色欲久久久天天天综合网精品 | 亚洲s码欧洲m码国产av | 久久久久久久女国产乱让韩 | 久久精品人人做人人综合 | 亚洲成色www久久网站 | 国产又粗又硬又大爽黄老大爷视 | 亚洲 日韩 欧美 成人 在线观看 | 国产亚洲欧美在线专区 | 欧美精品一区二区精品久久 | 精品人妻人人做人人爽 | 国产真人无遮挡作爱免费视频 | 乌克兰少妇性做爰 | 熟妇人妻无乱码中文字幕 | 亚洲国产一区二区三区在线观看 | 熟妇人妻激情偷爽文 | 国内精品人妻无码久久久影院 | 亚洲日韩乱码中文无码蜜桃臀网站 | 欧美国产日韩亚洲中文 | 国产精品美女久久久 | 偷窥村妇洗澡毛毛多 | 动漫av网站免费观看 | 曰本女人与公拘交酡免费视频 | 久久久无码中文字幕久... | 久久97精品久久久久久久不卡 | 亚洲日韩精品欧美一区二区 | 欧美喷潮久久久xxxxx | 亚洲娇小与黑人巨大交 | 免费人成在线视频无码 | 亚洲性无码av中文字幕 | 国产香蕉尹人综合在线观看 | 亚洲成色在线综合网站 | 99久久婷婷国产综合精品青草免费 | 国产高清不卡无码视频 | 成人欧美一区二区三区黑人 | 性色欲情网站iwww九文堂 | 图片小说视频一区二区 | 亚洲中文字幕久久无码 | 亚洲欧洲日本无在线码 | 亚洲中文无码av永久不收费 | 国产免费久久精品国产传媒 | 99精品国产综合久久久久五月天 | 亚洲 高清 成人 动漫 | 色老头在线一区二区三区 | 日本饥渴人妻欲求不满 | 久久久精品欧美一区二区免费 | 亚洲欧美日韩国产精品一区二区 | 小鲜肉自慰网站xnxx | 黑人粗大猛烈进出高潮视频 | 99精品国产综合久久久久五月天 | 亚洲综合另类小说色区 | 精品欧洲av无码一区二区三区 | 丰满人妻精品国产99aⅴ | 亚洲国产av美女网站 | 精品一区二区不卡无码av | 国产香蕉尹人综合在线观看 | 永久免费精品精品永久-夜色 | 久久www免费人成人片 | 极品嫩模高潮叫床 | 精品国产麻豆免费人成网站 | 亚洲乱亚洲乱妇50p | 天天做天天爱天天爽综合网 | 四十如虎的丰满熟妇啪啪 | 久久国产自偷自偷免费一区调 | 天天摸天天透天天添 | 国产小呦泬泬99精品 | 鲁大师影院在线观看 | 天堂在线观看www | 无码人妻黑人中文字幕 | 永久免费精品精品永久-夜色 | 中文字幕无码视频专区 | 无码国产色欲xxxxx视频 | 国产午夜手机精彩视频 | 亚洲区欧美区综合区自拍区 | 国产精品二区一区二区aⅴ污介绍 | 久久综合九色综合97网 | 午夜成人1000部免费视频 | 377p欧洲日本亚洲大胆 | 亚洲无人区午夜福利码高清完整版 | 偷窥村妇洗澡毛毛多 | 大乳丰满人妻中文字幕日本 | 97资源共享在线视频 | 久久综合九色综合97网 | 久久人妻内射无码一区三区 | 国产亚洲欧美日韩亚洲中文色 | 国产在线精品一区二区三区直播 | 欧美大屁股xxxxhd黑色 | 色诱久久久久综合网ywww | 亚洲 日韩 欧美 成人 在线观看 | 宝宝好涨水快流出来免费视频 | 国产成人综合在线女婷五月99播放 | 久久亚洲中文字幕精品一区 | 久久久成人毛片无码 | 在线欧美精品一区二区三区 | 亚洲国产精品一区二区第一页 | 国产精品成人av在线观看 | 精品国偷自产在线 | 99久久精品午夜一区二区 | 国产区女主播在线观看 | 色婷婷欧美在线播放内射 | 荫蒂被男人添的好舒服爽免费视频 | 中文字幕无码免费久久9一区9 | а天堂中文在线官网 | 亚洲国产精品无码一区二区三区 | 一本一道久久综合久久 | 国产成人精品一区二区在线小狼 | 在线观看免费人成视频 | √天堂资源地址中文在线 | 中文久久乱码一区二区 | 一本无码人妻在中文字幕免费 | 玩弄少妇高潮ⅹxxxyw | 18精品久久久无码午夜福利 | 夜精品a片一区二区三区无码白浆 | 99久久久无码国产精品免费 | 亚洲成a人片在线观看日本 | 国产xxx69麻豆国语对白 | 国产在线一区二区三区四区五区 | 亚洲第一网站男人都懂 | 国产一精品一av一免费 | 久久人人爽人人人人片 | 亚洲精品久久久久久久久久久 | 欧美性黑人极品hd | 红桃av一区二区三区在线无码av | 精品无码av一区二区三区 | 扒开双腿疯狂进出爽爽爽视频 | 日韩人妻少妇一区二区三区 | av小次郎收藏 | 亚洲区欧美区综合区自拍区 | 成人免费视频视频在线观看 免费 | 亚洲欧洲日本无在线码 | 最近中文2019字幕第二页 | 欧美 亚洲 国产 另类 | 女人被爽到呻吟gif动态图视看 | 亚洲国产综合无码一区 | 十八禁真人啪啪免费网站 | 成人综合网亚洲伊人 | 无码成人精品区在线观看 | 久久久成人毛片无码 | 3d动漫精品啪啪一区二区中 | a片在线免费观看 | 性欧美videos高清精品 | 国产99久久精品一区二区 | 国产黑色丝袜在线播放 |