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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

LeetCode算法题7:DFS和BFS

發(fā)布時(shí)間:2025/6/17 编程问答 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 LeetCode算法题7:DFS和BFS 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

文章目錄

  • 前言
    • 深度優(yōu)先搜索算法偽代碼:
    • 廣度優(yōu)先搜索算法偽代碼:
  • 一、圖像渲染
    • DFS:
    • BFS:
      • 上面BFS算法存在的問題:
      • 修改 1:
      • 修改 2:
  • 二、島嶼的最大面積
    • DFS:
    • BFS :
  • 三、合并二叉樹
    • DFS:
    • BFS:
      • 上面BFS算法存在的問題:
      • 修改 1:
      • 修改 2:
  • 四、填充每個(gè)節(jié)點(diǎn)的下一個(gè)右側(cè)節(jié)點(diǎn)指針
    • 思路 1:
      • 樹的層序遍歷
    • 思路 2:
  • 五、01矩陣
    • BFS:
    • DP:
  • 六、腐爛的橘子
    • BFS:
  • 總結(jié)


前言

??????Leetcode算法系列:https://leetcode-cn.com/study-plan/algorithms/?progress=njjhkd2

??????簡單總結(jié)一下DFS、BFS相關(guān)的算法題:

深度優(yōu)先搜索算法偽代碼:

??????一般需要建立一個(gè) visited 數(shù)組來標(biāo)記訪問過的元素。從一個(gè)節(jié)點(diǎn)開始,訪問它;找到它未被訪問過的后續(xù)節(jié)點(diǎn),遞歸執(zhí)行此算法。以下圖的二叉樹為例:訪問節(jié)點(diǎn)的順序依次為:A->B->C->D->E->F 類似于樹的先序遍歷。遍歷方式類似于先死磕一個(gè)方向打開缺口,再由缺口處擴(kuò)散來擴(kuò)大戰(zhàn)果,直至結(jié)束。

??????遞歸實(shí)現(xiàn)的偽代碼為:

function dfs(node, visited) {visit(node);//訪問元素visited[node]=true;//標(biāo)記已訪問for (node in node.children()) {if (visited[node]==false) //防止重復(fù)訪問同一個(gè)元素。dfs(node, visited);} }

廣度優(yōu)先搜索算法偽代碼:

??????此算法和樹的層序遍歷基本一致。一般需要建立一個(gè)輔助隊(duì)列。搜索方法為:一圈圈擴(kuò)散,從內(nèi)圈開始直到最外圍,隊(duì)列用來保持內(nèi)外圈的搜索順序(內(nèi)圈遍歷結(jié)束才能到外圈)。以上圖的二叉樹為例:訪問節(jié)點(diǎn)的順序依次為:A->B->E->C->D->F 類似于樹的層序遍歷。
??????遞歸實(shí)現(xiàn)的偽代碼 1:

function bfs(graph, root) {queue = [];queue.add([root]);int [] visited;visited[root]=true;while (!queue.isEmpty()) node = queue.pop();visit(node);for (node in node.children()&&visited[node]==false) {queue.add(node);visited[node]=true; }

??????遞歸實(shí)現(xiàn)的偽代碼 2:

function bfs(graph, root) {queue = [];queue.add([root]);visit(node);while (!queue.isEmpty()) node = queue.pop();for (node in node.children()) {queue.add(node);visit(node); }

??????廣度優(yōu)先偽代碼 1 和 2 的差別后面在具體的問題中會(huì)講到,一般常采用偽代碼 2的寫法(即建議應(yīng)該采用入隊(duì)時(shí)訪問,并且在某些情況下在出隊(duì)時(shí)訪問會(huì)造成錯(cuò)誤)。

一、圖像渲染

??????題目鏈接:https://leetcode-cn.com/problems/flood-fill/

??????題目描述:有一幅以 m x n 的二維整數(shù)數(shù)組表示的圖畫 image ,其中 image[i][j] 表示該圖畫的像素值大小。

你也被給予三個(gè)整數(shù) sr , sc 和 newColor 。你應(yīng)該從像素 image[sr][sc] 開始對圖像進(jìn)行 上色填充 。

為了完成 上色工作 ,從初始像素開始,記錄初始坐標(biāo)的 上下左右四個(gè)方向上 像素值與初始坐標(biāo)相同的相連像素點(diǎn),接著再記錄這四個(gè)方向上符合條件的像素點(diǎn)與他們對應(yīng) 四個(gè)方向上 像素值與初始坐標(biāo)相同的相連像素點(diǎn),……,重復(fù)該過程。將所有有記錄的像素點(diǎn)的顏色值改為 newColor 。

最后返回 經(jīng)過上色渲染后的圖像 。

DFS:

??????其中 oldColor 表示整個(gè)二維數(shù)組中值為 oldColor 的元素需要被更改為 newColor 。**下面的算法沒有采用 visited 數(shù)組來標(biāo)記訪問過的元素,因?yàn)橐坏┌l(fā)現(xiàn)元素的值為 oldColor,就會(huì)改變它的值為 newColor,不會(huì)造成程序多次訪問同一個(gè)值為 oldColor 的元素,**也不會(huì)導(dǎo)致程序陷入循環(huán)。因此:參考上面的 DFS 模板,如果 visit() 方法不會(huì)對訪問的元素造成改變,那么就需要一個(gè) visited 數(shù)組來進(jìn)行標(biāo)記,否則如本題這樣不需要 visited 數(shù)組的存在。參考算法如下:

public int[][] floodFill(int[][] image, int sr, int sc, int newColor) {int oldColor=image[sr][sc];if(oldColor!=newColor)floodFill0(image,sr,sc,oldColor,newColor);return image;}public void floodFill0(int[][] image, int sr, int sc, int oldColor, int newColor) {if(sr<0||sc<0||sr>=image.length||sc>=image[0].length||image[sr][sc]!=oldColor)return; //退出條件為數(shù)組元素越界或碰到不符合要求的元素(元素值不等于 oldColor)image[sr][sc]=newColor;floodFill0(image,sr+1,sc,oldColor,newColor);floodFill0(image,sr-1,sc,oldColor,newColor);floodFill0(image,sr,sc+1,oldColor,newColor);floodFill0(image,sr,sc-1,oldColor,newColor);}

??????稍微修改一下代碼,如下:

int[] x={1,0,-1,0};int[] y={0,1,0,-1};public int[][] floodFill(int[][] image, int sr, int sc, int newColor) {int oldColor=image[sr][sc];if(oldColor!=newColor)floodFill0(image,sr,sc,oldColor,newColor);return image;}public void floodFill0(int[][] image, int sr, int sc, int oldColor, int newColor) {if(sr<0||sc<0||sr>=image.length||sc>=image[0].length||image[sr][sc]!=oldColor)return;image[sr][sc]=newColor;for(int i=0;i<x.length;i++)floodFill0(image,sr+x[i],sc+y[i],oldColor,newColor);}

BFS:

??????從起點(diǎn)開始一圈圈往外擴(kuò)散。參考算法如下:

public int[][] floodFill(int[][] image, int sr, int sc, int newColor) {int oldColor=image[sr][sc];if(oldColor!=newColor){int[] dx={1,0,-1,0};int[] dy={0,1,0,-1};Queue<int[]> queue=new LinkedList<>();queue.offer(new int[]{sr,sc});while(!queue.isEmpty()){int[] cell=queue.poll();int x=cell[0],y=cell[1];image[x][y]=newColor;for(int i=0;i<dx.length;i++){int mx=x+dx[i],my=y+dy[i];if(mx<0||my<0||mx>=image.length||my>=image[0].length||image[mx][my]!=oldColor){continue;}queue.offer(new int[]{mx,my});}}}return image;}

上面BFS算法存在的問題:

??????按照本題描述中的示例,左上角 (0,0) 處的 1 會(huì)被添加進(jìn)隊(duì)列兩次,分別由(0,1) 處的 1 添加一次,(1,0) 處的 1 再添加一次。上述算法有可能導(dǎo)致同一個(gè)元素入隊(duì)多次,這是我們不希望看到的。而偽代碼 2 保證了 BFS 中每個(gè)元素只能入隊(duì)一次

修改 1:

??????偽代碼 2:在每個(gè)元素入隊(duì)時(shí)改變它的值為 newColor。參考如下:

public int[][] floodFill(int[][] image, int sr, int sc, int newColor) {int oldColor=image[sr][sc];if(oldColor!=newColor){int[] dx={1,0,-1,0};int[] dy={0,1,0,-1};Queue<int[]> queue=new LinkedList<>();queue.offer(new int[]{sr,sc});image[sr][sc]=newColor;while(!queue.isEmpty()){int[] cell=queue.poll();int x=cell[0],y=cell[1];for(int i=0;i<dx.length;i++){int mx=x+dx[i],my=y+dy[i];if(mx<0||my<0||mx>=image.length||my>=image[0].length||image[mx][my]!=oldColor){continue;}queue.offer(new int[]{mx,my});image[mx][my]=newColor;}}}return image;}

修改 2:

??????另一種方式即采用標(biāo)記數(shù)組,這樣需要在每次入隊(duì)時(shí)標(biāo)記元素為 true,修改如下:

public int[][] floodFill(int[][] image, int sr, int sc, int newColor) {boolean[][] visited=new boolean[image.length][image[0].length];int oldColor=image[sr][sc];if(oldColor!=newColor){int[] dx={1,0,-1,0};int[] dy={0,1,0,-1};Queue<int[]> queue=new LinkedList<>();queue.offer(new int[]{sr,sc});visited[sr][sc]=true;while(!queue.isEmpty()){int[] cell=queue.poll();int x=cell[0],y=cell[1];image[x][y]=newColor;for(int i=0;i<dx.length;i++){int mx=x+dx[i],my=y+dy[i];if(mx<0||my<0||mx>=image.length||my>=image[0].length||image[mx][my]!=oldColor||visited[mx][my]==true){continue;}queue.offer(new int[]{mx,my});visited[mx][my]=true;}}}return image;}

??????為了防止BFS中同一個(gè)元素多次入隊(duì)的情況產(chǎn)生,需要在每個(gè)元素入隊(duì)時(shí)采用操作(比如修改,單純的訪問是不行的),其實(shí)更通用的方式是采用標(biāo)記數(shù)組來實(shí)現(xiàn)。即像 DFS 那樣。

二、島嶼的最大面積

??????題目鏈接:https://leetcode-cn.com/problems/max-area-of-island/

??????題目描述:給你一個(gè)大小為 m x n 的二進(jìn)制矩陣 grid 。

島嶼 是由一些相鄰的 1 (代表土地) 構(gòu)成的組合,這里的「相鄰」要求兩個(gè) 1 必須在 水平或者豎直的四個(gè)方向上 相鄰。你可以假設(shè) grid 的四個(gè)邊緣都被 0(代表水)包圍著。

島嶼的面積是島上值為 1 的單元格的數(shù)目。

計(jì)算并返回 grid 中最大的島嶼面積。如果沒有島嶼,則返回面積為 0 。

DFS:

??????本題不會(huì)對訪問的元素造成改變,所以需要 visited 數(shù)組來標(biāo)記是否訪問過該元素。參考代碼如下:(當(dāng)然也可以仿照上一題修改訪問過元素的值,比如將訪問過的 1 均變?yōu)?2,這樣就不需要使用 visited 數(shù)組了。缺點(diǎn)是會(huì)對原來的數(shù)組狀態(tài)造成破環(huán)。)

int count=0;int[] x={1,0,0,-1};int[] y={0,1,-1,0};public int maxAreaOfIsland(int[][] grid) {int re=0,m=grid.length,n=grid[0].length;boolean[][] visited=new boolean[m][n];for(int i=0;i<m;i++){for(int j=0;j<n;j++){if(grid[i][j]==1&&visited[i][j]==false){//找到每一個(gè)未被訪問過的島嶼。計(jì)算并比較其面積count=0;DFS(grid,i,j,visited);if(count>re)re=count;}}}return re;}public void DFS(int[][] grid,int i,int j,boolean[][] visited){if(i<0||j<0||i>=grid.length||j>=grid[0].length||grid[i][j]!=1||visited[i][j]==true)return;visited[i][j]=true;count++;for(int k=0;k<x.length;k++)DFS(grid,i+x[k],j+y[k],visited);}

??????不帶有 visited 數(shù)組的 DFS 如下:

int count=0;int[] x={1,0,0,-1};int[] y={0,1,-1,0};public int maxAreaOfIsland(int[][] grid) {int re=0,m=grid.length,n=grid[0].length;int newValue=2;//用 2 來表示已經(jīng)探查過的島嶼。for(int i=0;i<m;i++){for(int j=0;j<n;j++){if(grid[i][j]==1){count=0;DFS(grid,i,j,newValue);if(count>re)re=count;}}}return re;}public void DFS(int[][] grid,int i,int j,int newValue){if(i<0||j<0||i>=grid.length||j>=grid[0].length||grid[i][j]!=1)return;grid[i][j]=newValue;count++;for(int k=0;k<x.length;k++)DFS(grid,i+x[k],j+y[k],newValue);}

BFS :

??????和上一題類似,需要在元素入隊(duì)的時(shí)候進(jìn)行標(biāo)記或修改操作(比如將值也置為 2 )來防止同一個(gè)元素多次入隊(duì);否則采用偽代碼 1 的解法會(huì)導(dǎo)致同一個(gè)元素多次入隊(duì),會(huì)造成多次計(jì)數(shù),這樣就不能得到正確結(jié)果了。

public int maxAreaOfIsland(int[][] grid) {int count=0;int[] x={1,0,0,-1};int[] y={0,1,-1,0};int re=0,m=grid.length,n=grid[0].length;boolean[][] visited=new boolean[m][n];Queue<int[]> queue=new LinkedList<>();for(int i=0;i<m;i++){for(int j=0;j<n;j++){if(grid[i][j]==1&&visited[i][j]==false){count=0;queue.offer(new int[]{i,j});visited[i][j]=true;while(!queue.isEmpty()){int[] tmp=queue.poll();count++;for(int k=0;k<x.length;k++){int newX=tmp[0]+x[k],newY=tmp[1]+y[k];if(newX<0||newY<0||newX>=m||newY>=n||grid[newX][newY]!=1||visited[newX][newY]==true) continue;queue.offer(new int[]{newX,newY});visited[newX][newY]=true;}}if(count>re)re=count;}}}return re;}

三、合并二叉樹

??????題目鏈接:https://leetcode-cn.com/problems/merge-two-binary-trees/

??????題目描述:給你兩棵二叉樹: root1 和 root2 。

想象一下,當(dāng)你將其中一棵覆蓋到另一棵之上時(shí),兩棵樹上的一些節(jié)點(diǎn)將會(huì)重疊(而另一些不會(huì))。你需要將這兩棵樹合并成一棵新二叉樹。合并的規(guī)則是:如果兩個(gè)節(jié)點(diǎn)重疊,那么將這兩個(gè)節(jié)點(diǎn)的值相加作為合并后節(jié)點(diǎn)的新值;否則,不為 null 的節(jié)點(diǎn)將直接作為新二叉樹的節(jié)點(diǎn)。

返回合并后的二叉樹。

注意: 合并過程必須從兩個(gè)樹的根節(jié)點(diǎn)開始。

DFS:

??????參考先序遍歷,先計(jì)算當(dāng)前節(jié)點(diǎn)的最終值,在遞歸進(jìn)行左右孩子節(jié)點(diǎn)值的判斷,在這里需要分情況計(jì)算的。參考算法如下(這個(gè)算法完全重建了一個(gè)新的樹):

public TreeNode mergeTrees(TreeNode root1, TreeNode root2) {if(root1!=null&&root2!=null)return new TreeNode(root1.val+root2.val,mergeTrees(root1.left,root2.left),mergeTrees(root1.right,root2.right));else if(root1==null&&root2!=null)return new TreeNode(root2.val,mergeTrees(null,root2.left),mergeTrees(null,root2.right));else if(root2==null&&root1!=null)return new TreeNode(root1.val,mergeTrees(root1.left,null),mergeTrees(root1.right,null));elsereturn null;}

??????不完全重建一個(gè)新的樹的算法如下:

public TreeNode mergeTrees(TreeNode root1, TreeNode root2) {if(root1!=null&&root2!=null)return new TreeNode(root1.val+root2.val,mergeTrees(root1.left,root2.left),mergeTrees(root1.right,root2.right));else if(root1==null&&root2!=null)return root2;else if(root2==null&&root1!=null)return root1;elsereturn null;}

??????或者下面這種,思路更加清晰一些,更加像樹的先序遍歷。

public TreeNode mergeTrees(TreeNode t1, TreeNode t2) {if (t1 == null) {return t2;}if (t2 == null) {return t1;}TreeNode merged = new TreeNode(t1.val + t2.val);merged.left = mergeTrees(t1.left, t2.left);merged.right = mergeTrees(t1.right, t2.right);return merged;}

BFS:

??????有兩個(gè)不算問題的問題:1,兩個(gè)數(shù)中的節(jié)點(diǎn)入隊(duì),如何保持相應(yīng)節(jié)點(diǎn)的一致性?2,假設(shè)已經(jīng)得到了最終樹的層序遍歷,如何恢復(fù)出一個(gè)樹?但其實(shí)問題并沒有想象中那么復(fù)雜,關(guān)鍵在于元素出隊(duì)之后要對此元素的左右孩子做判斷,來得到該位置上的最終節(jié)點(diǎn)。在這里只關(guān)心相應(yīng)的兩個(gè)節(jié)點(diǎn)均不為空的情形,若任意一個(gè)節(jié)點(diǎn)為空,新節(jié)點(diǎn)置為另一個(gè)不為空的節(jié)點(diǎn)。另外也不需要從層序遍歷恢復(fù)出一個(gè)樹,最終的目標(biāo)樹結(jié)構(gòu)在每一次元素出隊(duì)時(shí)都會(huì)建立一部分,直至結(jié)束。參考算法如下:()

public TreeNode mergeTrees(TreeNode root1, TreeNode root2) {LinkedList<TreeNode> q1=new LinkedList<>();LinkedList<TreeNode> q2=new LinkedList<>();LinkedList<TreeNode> q=new LinkedList<>();if(root1!=null&&root2!=null)q.offer(new TreeNode(root1.val+root2.val));else if(root1!=null)return root1;else if(root2!=null)return root2;else return null;TreeNode re=q.peek();q1.offer(root1);q2.offer(root2);while(!q1.isEmpty()){//這里的循環(huán)條件只要 q1 或 q2 不為空即可。TreeNode a=q1.poll(),b=q2.poll(),c=q.poll();TreeNode al=a.left,ar=a.right,bl=b.left,br=b.right;if(al!=null&&bl!=null){TreeNode tmp=new TreeNode(al.val+bl.val);c.left=tmp;q.offer(tmp);q1.offer(al);q2.offer(bl);}else if(al!=null)c.left=al;else if(bl!=null)c.left=bl;if(ar!=null&&br!=null){TreeNode tmp=new TreeNode(ar.val+br.val);c.right=tmp;q.offer(c.right);q1.offer(ar);q2.offer(br);}else if(ar!=null)c.right=ar;else if(br!=null)c.right=br;}return re;}

上面BFS算法存在的問題:

??????按照本題描述中的示例,左上角 (0,0) 處的 1 會(huì)被添加進(jìn)隊(duì)列兩次,分別由(0,1) 處的 1 添加一次,(1,0) 處的 1 再添加一次。上述算法有可能導(dǎo)致同一個(gè)元素入隊(duì)多次,這是我們不希望看到的。而偽代碼 2 保證了 BFS 一定要保證一個(gè)元素只能入隊(duì)一次

修改 1:

??????如果采用標(biāo)記數(shù)組的話,需要在每次入隊(duì)時(shí)標(biāo)記元素為 true,修改如下:

public int[][] floodFill(int[][] image, int sr, int sc, int newColor) {boolean[][] visited=new boolean[image.length][image[0].length];int oldColor=image[sr][sc];if(oldColor!=newColor){int[] dx={1,0,-1,0};int[] dy={0,1,0,-1};Queue<int[]> queue=new LinkedList<>();queue.offer(new int[]{sr,sc});visited[sr][sc]=true;while(!queue.isEmpty()){int[] cell=queue.poll();int x=cell[0],y=cell[1];image[x][y]=newColor;for(int i=0;i<dx.length;i++){int mx=x+dx[i],my=y+dy[i];if(mx<0||my<0||mx>=image.length||my>=image[0].length||image[mx][my]!=oldColor||visited[mx][my]==true){continue;}queue.offer(new int[]{mx,my});visited[mx][my]=true;}}}return image;}

修改 2:

??????本題另一種更好的修改方式為:在每個(gè)元素入隊(duì)時(shí)改變它的值為 newColor,這樣在功能上可以做到和標(biāo)記數(shù)組一樣的效果。參考如下:

public int[][] floodFill(int[][] image, int sr, int sc, int newColor) {int oldColor=image[sr][sc];if(oldColor!=newColor){int[] dx={1,0,-1,0};int[] dy={0,1,0,-1};Queue<int[]> queue=new LinkedList<>();queue.offer(new int[]{sr,sc});image[sr][sc]=newColor;while(!queue.isEmpty()){int[] cell=queue.poll();int x=cell[0],y=cell[1];for(int i=0;i<dx.length;i++){int mx=x+dx[i],my=y+dy[i];if(mx<0||my<0||mx>=image.length||my>=image[0].length||image[mx][my]!=oldColor){continue;}queue.offer(new int[]{mx,my});image[mx][my]=newColor;}}}return image;}

??????為了防止BFS中同一個(gè)元素多次入隊(duì)的情況產(chǎn)生,需要在每個(gè)元素入隊(duì)時(shí)采用操作(采用標(biāo)記數(shù)組或別的方式),DFS 不會(huì)存在這樣的問題,類似于先序遍歷,它是先對元素進(jìn)行操作,然后進(jìn)行遞歸調(diào)用的。

四、填充每個(gè)節(jié)點(diǎn)的下一個(gè)右側(cè)節(jié)點(diǎn)指針

??????題目鏈接:https://leetcode-cn.com/problems/populating-next-right-pointers-in-each-node/

??????題目描述:給定一個(gè) 完美二叉樹 ,其所有葉子節(jié)點(diǎn)都在同一層,每個(gè)父節(jié)點(diǎn)都有兩個(gè)子節(jié)點(diǎn)。二叉樹定義如下:

struct Node {
int val;
Node *left;
Node *right;
Node *next;
}
填充它的每個(gè) next 指針,讓這個(gè)指針指向其下一個(gè)右側(cè)節(jié)點(diǎn)。如果找不到下一個(gè)右側(cè)節(jié)點(diǎn),則將 next 指針設(shè)置為 NULL。

初始狀態(tài)下,所有 next 指針都被設(shè)置為 NULL。

思路 1:

樹的層序遍歷

??????在此給出一段代碼:用來分層打印出二叉樹結(jié)點(diǎn)信息。如何分層是通過兩個(gè)輔助變量做到的,其中 remainingNode 表示當(dāng)前層還未打印的結(jié)點(diǎn)數(shù)量,nextLayerN 表示下一層的結(jié)點(diǎn)數(shù)量。

public void printTree(){//分層打印樹節(jié)點(diǎn)。if(root==null)return;ArrayDeque<BinaryNode<T>> queue=new ArrayDeque<>();queue.offerLast(root);int remainingNode=1,nextLayerN=0;while(!queue.isEmpty()){BinaryNode<T> tmp=queue.pollFirst();System.out.print(tmp.element+" ");remainingNode--;if(tmp.left!=null){queue.offerLast(tmp.left);nextLayerN++;}if(tmp.right!=null){queue.offerLast(tmp.right);nextLayerN++;}if(remainingNode==0){System.out.println();remainingNode=nextLayerN;nextLayerN=0;}}}

??????參考上面樹的分層打印,可得到算法如下:

public Node connect(Node root) {if(root==null)return root;LinkedList<Node> q=new LinkedList<>();q.offer(root);int remain=1,nextLayer=0;while(!q.isEmpty()){Node tmp=q.poll();remain--;if(remain>=1)//所有最右側(cè)結(jié)點(diǎn)的 next 值在初始化時(shí)都為 nulltmp.next=q.peek();if(tmp.left!=null){q.offer(tmp.left);nextLayer++;}if(tmp.right!=null){q.offer(tmp.right);nextLayer++;}if(remain==0){remain=nextLayer;nextLayer=0;}}return root;}

思路 2:

??????在該完全二叉樹上,如果一個(gè)結(jié)點(diǎn)(node)存在左右結(jié)點(diǎn),那么直接令 node.left.next=node.right 即可,那么 node.right.next 的值呢?如果右邊沒有結(jié)點(diǎn),該值為 null;如果右邊存在結(jié)點(diǎn),那么 node.right.next=node.next.left;注意:在這里我們都是在上一層構(gòu)建當(dāng)前層的 next 關(guān)系的。可參考算法:

public Node connect(Node root) {if(root==null)return root;Node beforeL=root,tmp;//保存上一層的最左側(cè)結(jié)點(diǎn)while(beforeL.left!=null){tmp=beforeL;while(tmp!=null){//構(gòu)建當(dāng)前層的 next 指針關(guān)系tmp.left.next=tmp.right;if(tmp.next!=null)tmp.right.next=tmp.next.left;tmp=tmp.next;}beforeL=beforeL.left;}return root;}

五、01矩陣

??????題目鏈接:https://leetcode-cn.com/problems/01-matrix/

??????題目描述:給定一個(gè)由 0 和 1 組成的矩陣 mat ,請輸出一個(gè)大小相同的矩陣,其中每一個(gè)格子是 mat 中對應(yīng)位置元素到最近的 0 的距離。

兩個(gè)相鄰元素間的距離為 1 。

BFS:

??????一般來講,BFS 算法可以參考樹的層序遍歷算法(分層遍歷),之前講過,BFS 可以看作是一圈圈擴(kuò)散的,在本題中,初始值(初始入隊(duì)值的數(shù)量)并非只有 1 個(gè),而是 n 個(gè) 0,但是這 n 個(gè) 0 可以抽象為一個(gè),稱為超級源點(diǎn)。

??????因?yàn)樗嵌鄠€(gè)源點(diǎn)的抽象,對它的處理方法和只有一個(gè)源點(diǎn)的方法沒有本質(zhì)上的區(qū)別。然后需要將這些 0 周圍距離為 1 的點(diǎn)設(shè)置為 1,將這些 1 周圍距離為 1 的點(diǎn)設(shè)置為 2 ,以此類推。

??????需要注意 BFS 一定需要防止同一個(gè)元素多次入隊(duì),用標(biāo)記數(shù)組的話需要在入隊(duì)時(shí)更改元素標(biāo)記,而不是在出隊(duì)時(shí)。參考算法如下:

public int[][] updateMatrix(int[][] mat) {if(mat==null||mat.length==0||mat[0].length==0)return new int[0][0];int m=mat.length,n=mat[0].length;LinkedList<int[]> queue=new LinkedList<>();boolean[][] flag=new boolean[m][n];//用來防止重復(fù)入隊(duì)int numCurr=0,numNext=0,valueCurr=0;for(int i=0;i<m;i++)//將超級源點(diǎn)入隊(duì)(即所有為 0 的點(diǎn))for(int j=0;j<n;j++)if(mat[i][j]==0){queue.add(new int[]{i,j});flag[i][j]=true;numCurr++;}int[] tmp;int i,j; while(!queue.isEmpty()){tmp=queue.poll();numCurr--;i=tmp[0];j=tmp[1];if(j+1<n&&flag[i][j+1]==false){queue.add(new int[]{i,j+1});flag[i][j+1]=true;numNext++;}if(j-1>=0&&flag[i][j-1]==false){queue.add(new int[]{i,j-1});flag[i][j-1]=true;numNext++;}if(i+1<m&&flag[i+1][j]==false){queue.add(new int[]{i+1,j});flag[i+1][j]=true;numNext++;}if(i-1>=0&&flag[i-1][j]==false){queue.add(new int[]{i-1,j});flag[i-1][j]=true;numNext++;}mat[i][j]=valueCurr;if(numCurr==0){valueCurr++;numCurr=numNext;numNext=0;}}return mat;}

??????上面代碼是在出隊(duì)的時(shí)候重新設(shè)置 mat 數(shù)組的值,為了和入隊(duì)時(shí)設(shè)置 flag 統(tǒng)一,將其也放在入隊(duì)的時(shí)候。順便也換一種寫法,如下:

public int[][] updateMatrix(int[][] mat) {if(mat==null||mat.length==0||mat[0].length==0)return new int[0][0];int[] x={1,0,0,-1},y={0,1,-1,0};int m=mat.length,n=mat[0].length;LinkedList<int[]> queue=new LinkedList<>();boolean[][] flag=new boolean[m][n];int numCurr=0,numNext=0;for(int i=0;i<m;i++)for(int j=0;j<n;j++)if(mat[i][j]==0){queue.add(new int[]{i,j});flag[i][j]=true;numCurr++;}int[] tmp;int i,j; while(!queue.isEmpty()){tmp=queue.poll();numCurr--;i=tmp[0];j=tmp[1];for(int k=0;k<4;k++){int newI=i+x[k],newJ=j+y[k];if(newI>=0&&newI<m&&newJ>=0&&newJ<n&&flag[newI][newJ]==false){queue.add(new int[]{newI,newJ});numNext++;flag[newI][newJ]=true;mat[newI][newJ]=mat[i][j]+1;}}if(numCurr==0){numCurr=numNext;numNext=0;}}return mat;}

DP:

??????動(dòng)態(tài)規(guī)劃的做法是請參考題解。它不需要從所有為 0 的點(diǎn)處開始計(jì)算,而是取決于狀態(tài)轉(zhuǎn)移:dp[i][j]=Math.min(dp[i][j],dp[i-1][j]+1,dp[i+1][j]+1,dp[i][j-1]+1,dp[i][j+1]+1),其中 dp[i][j]表示在(i,j)處的元素距離最近的 0 處的距離,即任意一個(gè)位置的距離是它本身和周圍四個(gè)格子的距離加一之間的最小值。實(shí)現(xiàn)的算法比較巧妙,第一次遍歷實(shí)現(xiàn)一半的狀態(tài)轉(zhuǎn)移(從任意位置的左上方開始),另一次遍歷實(shí)現(xiàn)另一半的轉(zhuǎn)臺轉(zhuǎn)移(從右下方開始),從而得到最終結(jié)果。參考算法如下:

public int[][] updateMatrix(int[][] mat) {int i,j,m=mat.length,n=mat[0].length; int[][] dp=new int[m][n];for(i=0;i<m;i++) //初始化 dp 數(shù)組,for(j=0;j<n;j++){if(mat[i][j]!=0)dp[i][j]=Integer.MAX_VALUE/2;}for(i=0;i<m;i++) //從左上方開始遍歷for(j=0;j<n;j++){if(i-1>=0)dp[i][j]=Math.min(dp[i][j],dp[i-1][j]+1);if(j-1>=0)dp[i][j]=Math.min(dp[i][j],dp[i][j-1]+1);}for(i=m-1;i>=0;i--) //從左上方開始遍歷for(j=n-1;j>=0;j--){if(i+1<m)dp[i][j]=Math.min(dp[i][j],dp[i+1][j]+1);if(j+1<n)dp[i][j]=Math.min(dp[i][j],dp[i][j+1]+1);}return dp;}

六、腐爛的橘子

??????題目鏈接:https://leetcode-cn.com/problems/rotting-oranges/

??????題目描述:在給定的 m x n 網(wǎng)格 grid 中,每個(gè)單元格可以有以下三個(gè)值之一:

值 0 代表空單元格;
值 1 代表新鮮橘子;
值 2 代表腐爛的橘子。
每分鐘,腐爛的橘子 周圍 4 個(gè)方向上相鄰 的新鮮橘子都會(huì)腐爛。

返回 直到單元格中沒有新鮮橘子為止所必須經(jīng)過的最小分鐘數(shù)。如果不可能,返回 -1 。

BFS:

??????這道題很適合用 BFS,因?yàn)閺囊蝗Φ搅硪蝗?#xff0c;剛好 time 加一。所以采用超級源點(diǎn)的 BFS,在入隊(duì)的時(shí)候更改相應(yīng)的 grid 值。參考算法如下:

public int orangesRotting(int[][] grid) {int[] xa={0,1,0,-1};int[] ya={1,0,-1,0};int m=grid.length,n=grid[0].length;int[][] store=new int[m][n];LinkedList<int[]> queue=new LinkedList<>();int currT=0,num1=0;for(int i=0;i<m;i++)for(int j=0;j<n;j++){if(grid[i][j]==2){queue.add(new int[]{i,j});currT++;}else if(grid[i][j]==1)num1++;}if(num1==0) //特殊情況。return 0; int time=-1,x,y,nextT=0,xx,yy;int[] tmp;while(!queue.isEmpty()){tmp=queue.poll();x=tmp[0];y=tmp[1];currT--;for(int i=0;i<4;i++){xx=x+xa[i];yy=y+ya[i];if(xx>=0&&xx<m&&yy>=0&&yy<n&&grid[xx][yy]==1){grid[xx][yy]=2;queue.add(new int[]{xx,yy});nextT++;num1--;}}if(currT==0){time++;currT=nextT;nextT=0;}}if(num1!=0)return -1;return time;}

總結(jié)

??????完。

總結(jié)

以上是生活随笔為你收集整理的LeetCode算法题7:DFS和BFS的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

91精品国产自产91精品 | 亚洲日本在线一区 | 福利在线看片 | 人人澡超碰碰97碰碰碰软件 | 国产高清av免费在线观看 | 久久亚洲综合国产精品99麻豆的功能介绍 | 日日日视频 | 91在线精品一区二区 | 少妇18xxxx性xxxx片 | 国产高清在线观看av | 一级欧美一级日韩 | www.69xx| 999视频精品 | 国产成人精品一区二区在线 | 人人超碰免费 | 日本在线中文在线 | 日韩综合一区二区三区 | 久久久久北条麻妃免费看 | 日韩激情在线 | 少妇性aaaaaaaaa视频 | 草久久久久久久 | 天天干视频在线 | 成人久久网 | 正在播放国产精品 | 欧美亚洲一级片 | 国产91全国探花系列在线播放 | 欧美二区三区91 | 亚洲视频综合 | 精品久久久久久久久久久久久久久久久久 | 一区二区三区韩国免费中文网站 | 在线久热 | 欧美一区二区三区四区夜夜大片 | 成人黄大片视频在线观看 | 在线午夜 | 久久午夜电影院 | 国产精品美女久久久久久 | 午夜精品99久久免费 | 又大又硬又黄又爽视频在线观看 | 一级片观看 | 久久精品视频网 | 国产精品手机在线观看 | 日韩av免费在线看 | 色婷丁香| 午夜av剧场| 91人人视频在线观看 | 五月天综合网站 | 国产精品成人自产拍在线观看 | 久久精品波多野结衣 | 国产拍揄自揄精品视频麻豆 | 欧美亚洲另类在线视频 | 久久久久久久久久久久久久av | 天天激情 | 香蕉成人在线视频 | 丁香五香天综合情 | 午夜av免费看 | 日韩av电影网站在线观看 | 欧美成人中文字幕 | 在线观看色网 | 午夜国产在线 | 国产伦理一区 | 五月激情亚洲 | 中文乱幕日产无线码1区 | 国产一级免费观看 | 人人草人人草 | 黄色av网站在线观看免费 | 亚洲精品视频国产 | 成人午夜电影网站 | 天天色影院| av九九九| 久久免费99精品久久久久久 | 久久毛片高清国产 | 日本爱爱片 | 在线播放 日韩专区 | 久久激情日本aⅴ | 国产一区二区三区免费观看视频 | 日本中文字幕网 | 久久精品视频观看 | 精品久久久久久亚洲 | 九九天堂| 午夜日b视频 | 国产无遮挡又黄又爽馒头漫画 | 成人在线播放免费观看 | 日韩精品久久久久久久电影竹菊 | 国产精品久久久久久久久久久久午夜片 | 日日操日日插 | 国产精品一区二区久久精品爱涩 | 亚洲经典视频在线观看 | 国产精品久久久久影院日本 | 特级毛片在线观看 | 欧美国产一区二区 | 蜜臀av.com | 中文字幕在线观看第一区 | 日韩av中文 | 国产在线观看a | 久久久久婷| 精品国产免费av | 中文视频在线播放 | 色噜噜日韩精品欧美一区二区 | 精品一区二区三区久久 | 婷婷丁香综合 | 99热在线精品观看 | 人人爽人人爽人人片av | 人人爽人人片 | 97在线精品视频 | 久久久精品免费观看 | 久久国产一区二区 | 久久久久久久久爱 | 亚洲日本欧美在线 | 免费h视频 | 精品不卡av | 免费看黄在线观看 | 在线电影中文字幕 | 欧美性性网 | 中文字幕影视 | 精品亚洲网 | 国产高清视频在线免费观看 | 天天想夜夜操 | 国产精品日韩在线 | 日韩午夜小视频 | 日韩精品首页 | 福利一区在线视频 | 欧美一区二区三区在线播放 | 欧美在线free | 久久免费在线观看视频 | 免费的黄色的网站 | 在线观看国产高清视频 | 亚洲精品国偷拍自产在线观看蜜桃 | 丁香婷婷激情 | 日韩av手机在线看 | 91最新视频 | 日韩69av| 国产玖玖精品视频 | 久久精品影片 | 国内精品久久久久久久影视麻豆 | www视频免费在线观看 | 国产一区私人高清影院 | 午夜视频在线观看一区二区三区 | 日韩久久久久久久久久久久 | 国产一级二级在线 | 狠狠狠色丁香综合久久天下网 | 欧美日韩三级 | 久久不卡国产精品一区二区 | 狠狠色噜噜狠狠狠狠2021天天 | 久久成人亚洲欧美电影 | 天天曰天天爽 | av在线com| 在线 欧美 日韩 | 99视频偷窥在线精品国自产拍 | 亚洲精品免费看 | 亚洲欧洲成人精品av97 | 久久久av免费 | 欧美激情精品久久久久 | 中文字幕不卡在线88 | 二区视频在线观看 | 国产一级二级三级在线观看 | 国产又粗又猛又黄又爽视频 | 狠色在线| 免费在线观看不卡av | 天天干天天干天天干天天干天天干天天干 | 国产在线欧美在线 | 国产在线精品视频 | www.亚洲精品在线 | 亚洲精品大全 | 国产裸体永久免费视频网站 | 亚洲国产中文字幕在线 | 人人爽人人爽人人片 | 久久久久久久av麻豆果冻 | 狠狠干夜夜操 | 黄色一级影院 | 一级黄色片在线观看 | 69国产成人综合久久精品欧美 | 久久久久久亚洲精品 | 日本久久久久久久久久久 | 麻豆首页| 人人狠狠 | 国产资源网站 | 91看片黄色| 国产日本亚洲 | 91九色成人蝌蚪首页 | 日本女人的性生活视频 | 网站在线观看你们懂的 | 日本精品在线看 | 97人人精品| 公与妇乱理三级xxx 在线观看视频在线观看 | 在线观看 国产 | 五月在线| 国产精品毛片一区二区 | 九九视频这里只有精品 | 亚洲情感电影大片 | 欧美日韩精品综合 | 日韩一区二区久久 | 人人澡人人爱 | 日韩精品一区二区三区三炮视频 | 亚洲视频每日更新 | 久久久亚洲网站 | 国产视频在线观看一区 | 久久涩涩网站 | 手机在线日韩视频 | 六月丁香久久 | 一级黄毛片 | 国产区在线看 | 久草国产视频 | 91色在线观看 | 青春草免费在线视频 | 91精品久久久久久久久 | 欧洲在线免费视频 | 亚洲久草网 | 成人午夜久久 | 亚洲天天摸日日摸天天欢 | 青青河边草手机免费 | 欧美日韩性视频在线 | 西西www4444大胆视频 | 人人玩人人添人人澡超碰 | 俺要去色综合狠狠 | 欧美一级电影在线观看 | 国产亚洲欧洲 | 国产精品免费久久久久久久久久中文 | 亚洲视频1区2区 | 亚洲美女视频在线观看 | 国产精品久久久久久久久久99 | 伊人婷婷综合 | 最近久乱中文字幕 | 亚洲一级在线观看 | 蜜臀av性久久久久蜜臀aⅴ涩爱 | 精品久久一级片 | 成人性生交大片免费观看网站 | 久久免费国产精品 | 国产永久免费观看 | 97在线免费观看视频 | 夜夜夜夜夜夜操 | 欧美a√大片 | 精品美女久久久久久免费 | 99久久精品久久久久久动态片 | 91探花视频 | 婷婷伊人网| 国产日韩欧美在线观看 | 波多野结衣在线视频一区 | 亚洲 综合 精品 | 91精品一区二区三区蜜臀 | 国内久久久久久 | 激情五月视频 | 免费在线视频一区二区 | 热久久视久久精品18亚洲精品 | 精品自拍sae8—视频 | 美女视频永久黄网站免费观看国产 | 国产精品九九九 | 91九色porny蝌蚪视频 | 九草视频在线观看 | 色综合天天 | 一区二区电影网 | av在线免费观看不卡 | 99精品视频在线看 | 国产96在线观看 | 日本精品在线 | 婷婷亚洲激情 | 亚洲天天在线日亚洲洲精 | 91c网站色版视频 | 国产夫妻av在线 | 亚洲乱亚洲乱妇 | 五月天丁香 | 日韩电影在线观看一区 | 亚洲婷婷网 | 中国精品一区二区 | 91刺激视频| 亚洲年轻女教师毛茸茸 | 激情五月播播久久久精品 | 亚洲视频在线观看网站 | 黄色性av| 亚洲国产精品500在线观看 | 精品99久久 | 中文字幕色站 | 天天干天天操天天入 | 欧美专区国产专区 | 美腿丝袜一区二区三区 | 国产原创在线 | 久久精品中文 | 丝袜美腿亚洲 | 久久福利电影 | 在线看国产日韩 | 欧美色操| 久草在线这里只有精品 | 免费a视频在线观看 | 国产亚洲精品久久网站 | 久久精品免费看 | h文在线观看免费 | 毛片久久久 | 欧美视频xxx| 中文字幕在线播放日韩 | 91资源在线视频 | 中文字幕激情 | 日韩大片免费观看 | 九色视频网 | 亚洲欧美综合精品久久成人 | 在线视频成人 | 亚洲黄色在线看 | 在线视频免费观看 | 99久久综合精品五月天 | 91超碰在线播放 | 97超碰国产精品 | 免费亚洲黄色 | 成人9ⅰ免费影视网站 | 国产一区精品在线观看 | 成人小视频在线观看免费 | 丁香花在线视频观看免费 | 黄色免费电影网站 | 久久这里只有精品9 | 成年人黄色大片在线 | 国产高清精 | 久久久久观看 | 国产精品18毛片一区二区 | 免费观看www7722午夜电影 | 日本三级国产 | 99精品在这里 | 黄色com | 国产护士hd高朝护士1 | 这里只有精品视频在线 | 99精品久久99久久久久 | 日韩欧美在线综合网 | www.狠狠操.com | 在线天堂中文在线资源网 | 亚洲精品国产精品99久久 | 久久久久久久久久久网 | av免费电影网站 | 99久久久久久 | 国产成人a亚洲精品 | 超碰在线公开 | 91精品一区国产高清在线gif | 亚洲一级片免费观看 | 国产成人精品a | 五月天色网站 | 亚洲在线网址 | 久久久免费 | 天天操天操 | 久久久精品成人 | 91免费高清观看 | 深爱婷婷网 | 精品国产成人av在线免 | 中文字幕在线播放日韩 | 中文字幕视频网站 | 人人插超碰| 91网免费看 | 国产精品精品久久久久久 | 天堂av官网| 综合久久影院 | 操操操人人| 久久久久9999亚洲精品 | 久久av不卡 | 三级黄色在线 | 成人精品视频久久久久 | 中文视频在线 | 国产一二三四在线观看视频 | 99国产情侣在线播放 | 久草在线观看视频免费 | 国产视频1区2区 | 久在线观看视频 | 天天爱天天草 | 亚洲h色精品 | 五月婷婷开心中文字幕 | 亚洲成人第一区 | 激情婷婷亚洲 | 在线免费观看羞羞视频 | 三级小视频在线观看 | 国产不卡在线视频 | 99久热在线精品 | 69视频国产| 91麻豆免费版 | 国产99久久九九精品 | 国产亚洲精品久久久久秋 | 美女视频又黄又免费 | 成人av在线看 | 成人影片在线免费观看 | 免费在线观看日韩欧美 | 91视频在线免费 | 欧美日韩中文字幕视频 | 日韩电影一区二区三区在线观看 | 六月天综合网 | 色噜噜在线观看视频 | 国产在线免费观看 | 91麻豆精品国产自产 | 九九日九九操 | 在线免费精品视频 | 国产91精品看黄网站在线观看动漫 | 日韩精品一区不卡 | 三级视频片 | 人人视频网站 | 高清不卡毛片 | 国产精品自产拍在线观看中文 | 亚洲精品日韩在线观看 | 91漂亮少妇露脸在线播放 | 在线黄色av电影 | 亚洲国产精品999 | 国内三级在线观看 | 99久久婷婷国产 | 99久久精品免费看国产四区 | 国产精品一区二区三区在线免费观看 | 麻豆视传媒官网免费观看 | 亚洲黄色app | 久青草视频在线观看 | 日本久久成人中文字幕电影 | 久久精品视频免费观看 | 欧美有色 | 不卡电影一区二区三区 | 久久黄色精品视频 | 国产亚洲精品久久久久久 | 国产免费人成xvideos视频 | 婷婷色狠狠 | 久久99精品久久只有精品 | 91精品在线免费观看视频 | 国产精品一区二区 91 | 午夜久久影院 | 国产精品区二区三区日本 | 在线观看av免费观看 | 夜夜干夜夜 | 亚洲婷婷在线视频 | 国产不卡一区二区视频 | 五月婷婷综合网 | 激情丁香5月 | 亚洲精品美女久久 | 色婷婷免费 | 国内99视频 | 免费三级在线 | 人人爽网站| 九九九九九九精品任你躁 | 国产一二区精品 | 91亚洲狠狠婷婷综合久久久 | 精品久久久999| 丁香激情综合国产 | 婷婷丁香在线视频 | 国产电影黄色av | 在线观看网站av | 国产五月 | 国产一区二区在线观看视频 | www.黄色片网站 | 国产一区二区免费 | 亚洲另类视频在线观看 | 天天爽天天搞 | 亚洲精品456在线播放乱码 | 亚洲成人黄色在线 | 黄色成人毛片 | 一区二区精品在线 | 国产精品一区二区中文字幕 | 亚洲最新在线视频 | 欧美aaa大片| 一二三精品视频 | 视频一区视频二区在线观看 | 国产日产精品一区二区三区四区 | 久久久久久久免费 | 成年人免费看的视频 | 日韩在线观看视频网站 | av一级片网站 | 久久国产香蕉视频 | 色婷婷免费| 二区三区在线视频 | 六月婷婷网| 91在线精品秘密一区二区 | 五月天亚洲婷婷 | 天天干天天干天天干天天干天天干天天干 | 日韩av手机在线看 | 亚洲国产网站 | 亚洲国产精品va在线 | 日韩 在线a | 一区二区三区在线观看中文字幕 | 日日夜操| av在观看 | 精品产品国产在线不卡 | 最新色站 | 国产日韩在线一区 | 美女免费黄视频网站 | 国产四虎影院 | 久草国产精品 | 久久99精品国产99久久6尤 | 免费观看久久久 | 久久精品人人做人人综合老师 | 日韩精品亚洲专区在线观看 | 国产精品成人在线观看 | 婷婷六月综合网 | 在线看片中文字幕 | .精品久久久麻豆国产精品 亚洲va欧美 | 五月天久久综合 | 国产美女精彩久久 | 欧美日韩免费一区 | 亚洲精品18日本一区app | 毛片黄色一级 | 国产精品永久久久久久久www | 色婷婷激情四射 | 看毛片网站 | 国产精品久久一区二区三区不卡 | 国产精品久久久久9999 | 国产小视频在线看 | 国产三级香港三韩国三级 | 一区二区欧美在线观看 | 亚洲区另类春色综合小说校园片 | 久久激五月天综合精品 | 欧美日韩激情网 | 免费成视频 | 成年人视频在线 | 91成人免费在线视频 | 麻豆视频在线免费看 | 国产高清小视频 | 9999免费视频 | 看毛片网站| 久久久综合色 | 超碰人人干人人 | 日韩欧美高清在线 | 91在线精品视频 | 国产麻豆精品久久一二三 | 欧美成人免费在线 | 黄色成人影视 | 国产精品ssss在线亚洲 | 久久久久免费视频 | 免费观看一级一片 | 一区二区精品国产 | 人人精久| 91av原创| 国产精品原创av片国产免费 | 国产视频在线观看一区 | 亚洲五月花 | 久福利 | 中文字幕在线有码 | 免费看的黄色录像 | 成年人在线免费看 | 欧美激情第八页 | 久久综合九色综合久99 | 日韩欧美91 | 中文字幕久久精品亚洲乱码 | 国产精品免费在线视频 | 国产精选视频 | 在线观看激情av | 香蕉手机在线 | 久久99免费视频 | 香蕉蜜桃视频 | 欧美性色xo影院 | 五月天六月婷婷 | 久草电影免费在线观看 | 开心丁香婷婷深爱五月 | 伊人视频 | 免费色婷婷 | 一本—道久久a久久精品蜜桃 | 最近日本韩国中文字幕 | 香蕉视频在线网站 | av电影一区二区 | 夜夜躁日日躁狠狠久久88av | 黄色一级大片在线免费看产 | www.在线观看av | 日本爱爱免费视频 | 五月激情丁香婷婷 | 精品影院 | 中文字幕一区二区在线观看 | 国内精品99| 国产在线资源 | 91女人18片女毛片60分钟 | 免费网站色 | 欧美国产视频在线 | 天天av资源| 国产高清在线一区 | 日韩中文字幕a | 伊人婷婷久久 | 国产免费黄色 | 日本公乱妇视频 | 欧美午夜理伦三级在线观看 | 国产 在线观看 | 在线成人小视频 | 欧美夫妻性生活电影 | 欧美日韩精品在线 | 九九热久久久 | 天堂视频一区 | 五月黄色 | 国产精品第7页 | 日韩av中文在线观看 | 黄色一区三区 | 国产精品日韩在线观看 | 狠狠干夜夜 | 天天射日 | 夜夜骑首页 | 欧美国产日韩一区二区三区 | 国产麻豆剧传媒免费观看 | 亚洲丝袜一区 | 天堂av免费在线 | 一区二区影院 | 久草在在线| 欧美精品999| 91视频在线观看免费 | 国产第一福利网 | 欧美一级黄大片 | 激情视频国产 | 欧亚日韩精品一区二区在线 | 亚洲日本精品视频 | 久久一区国产 | 麻豆精品视频 | 激情丁香婷婷 | 中文字幕91在线 | 五月激情姐姐 | 99国内精品 | 亚洲激情在线观看 | 天堂网av 在线 | 夜夜摸夜夜爽 | 色91在线视频| 国产高清视频免费最新在线 | 91精彩在线视频 | 美女又爽又黄 | 性色av免费观看 | av中文字幕免费在线观看 | 成人一级片在线观看 | 亚洲国产精品久久久 | 国产日产精品一区二区三区四区的观看方式 | 四虎免费在线观看视频 | 亚洲免费观看在线视频 | 久久精品一区二区三区中文字幕 | 中文av在线天堂 | 中日韩在线 | 精品国产精品久久 | 综合激情 | 中文字幕乱码电影 | 91精品中文字幕 | 国产精品黑丝在线观看 | 亚洲精品午夜久久久久久久 | 玖玖在线视频观看 | 美女网站在线 | 成人免费视频免费观看 | 一区二区三区在线观看中文字幕 | a在线免费观看视频 | 最新中文字幕在线资源 | 国产黄色在线看 | 在线黄色毛片 | 超碰九九 | 色.www| 国产一级黄色免费看 | 亚洲性视频 | 色视频在线看 | 国产专区欧美专区 | 精品亚洲欧美一区 | 成人黄色在线观看视频 | 欧美日韩国产亚洲乱码字幕 | 国际精品久久 | 日日弄天天弄美女bbbb | 亚洲综合在线视频 | 久久人人精品 | 亚洲在线国产 | 精品中文字幕在线观看 | 婷婷色五 | 五月天激情综合 | 久久精品二区 | 在线看国产视频 | 中文区中文字幕免费看 | 又色又爽又黄 | 深夜免费福利网站 | 久久久精品视频网站 | 9797在线看片亚洲精品 | 亚洲午夜av久久乱码 | 最近高清中文字幕在线国语5 | 在线观看成人av | 视频二区 | 国产精品美女视频网站 | 91在线视频在线 | av电影在线免费观看 | 欧美日韩亚洲第一 | 超碰成人网| 精品国产观看 | 911精品美国片911久久久 | 国产亚洲精品日韩在线tv黄 | av丝袜天堂 | 天天曰天天曰 | 免费福利片2019潦草影视午夜 | 国产精品va最新国产精品视频 | 日韩精品国产一区 | 成人av免费在线观看 | 国产精品久久久久久久久免费看 | 日日夜夜精品视频天天综合网 | 日韩免费电影在线观看 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 91久久精品一区二区三区 | 日韩精品视频在线免费观看 | 在线91精品 | 国产在线观看二区 | 婷婷综合国产 | 亚洲精品视频在线观看网站 | 精品国产免费人成在线观看 | 国产精品女视频 | 国产精品青草综合久久久久99 | 99 色| 国产日产亚洲精华av | 亚洲成人第一区 | 91综合视频在线观看 | 国产精品久久久久久久av电影 | 五月天视频网 | 美女国内精品自产拍在线播放 | 日韩中文字幕视频在线 | 久久久久久久久影视 | 操操操综合 | 四虎永久网站 | 粉嫩av一区二区三区入口 | 伊人狠狠色丁香婷婷综合 | 亚洲aⅴ在线观看 | 天天撸夜夜操 | 免费69视频 | 国产九九九视频 | 96亚洲精品久久久蜜桃 | 国产超碰97 | 中文字幕精品久久 | 九九av | 在线日韩一区 | 粉嫩av一区二区三区四区 | 天天操天天干天天操天天干 | 粉嫩av一区二区三区四区在线观看 | 四虎影视成人 | 99热国产在线 | 一区二区三区高清在线 | 国产福利一区在线观看 | 免费男女羞羞的视频网站中文字幕 | 黄色成人小视频 | 丁香激情婷婷 | 国产精品理论片在线观看 | 日韩精品欧美专区 | 好看av在线 | 国产黄色片久久久 | 国产精品一区二区三区在线 | 国产成人一二三 | 亚洲欧美激情插 | 色老板在线视频 | 久久69精品 | 中文字幕 第二区 | 成人av在线播放网站 | 亚洲码国产日韩欧美高潮在线播放 | 色婷婷丁香| 国产精品永久免费 | 国内视频一区二区 | 亚洲精品玖玖玖av在线看 | 国产精品久久久久久久久蜜臀 | 天天操天天添 | 在线亚洲人成电影网站色www | 91久久奴性调教 | 欧美日韩国产在线 | 日韩乱色精品一区二区 | 国产精品91一区 | 欧美日韩另类在线观看 | 最近中文字幕完整视频高清1 | 亚洲一区精品二人人爽久久 | 久久久九色精品国产一区二区三区 | 91中文字幕| 97免费 | 国产精品嫩草在线 | 一本色道久久综合亚洲二区三区 | 中文字幕在线观看第二页 | 国产色视频| 欧美日韩一级久久久久久免费看 | 日韩精品最新在线观看 | 日日夜夜婷婷 | 久久有精品| 国产高清视频网 | 国产一区二区三区午夜 | 亚洲国产97在线精品一区 | 97在线视频观看 | 午夜精品一区二区三区在线播放 | 伊人国产在线观看 | 亚洲免费国产视频 | 亚洲精品福利在线观看 | 国产婷婷视频在线 | 久久av在线播放 | 久草在线视频精品 | 色婷婷在线视频 | 日b视频国产 | 色综合久久88色综合天天6 | 日韩最新理论电影 | 69国产成人综合久久精品欧美 | 又黄又爽又色无遮挡免费 | 国产免费专区 | 激情黄色av | 国产精品高清一区二区三区 | 日韩av电影一区 | 国产主播大尺度精品福利免费 | 成片视频免费观看 | 国产精品九九热 | 久久97久久97精品免视看 | 成人夜晚看av | 亚洲综合视频在线观看 | 福利视频网址 | 欧美日韩高清一区二区 | 国产剧情在线一区 | 国产在线黄色 | 日韩国产精品久久久久久亚洲 | 国产精品一二三 | www日韩在线| 色婷婷综合久久久 | 国产午夜三级一区二区三桃花影视 | 色婷婷狠狠五月综合天色拍 | 91在线操| 国产a国产a国产a | 国产美女黄网站免费 | 毛片精品免费在线观看 | 在线国产一区二区 | 久久久免费国产 | 免费看日韩 | 国产久草在线观看 | 国产成人精品免费在线观看 | 天天做日日做天天爽视频免费 | 久久精品视频在线播放 | 粉嫩高清一区二区三区 | www.亚洲精品视频 | 国产中文字幕亚洲 | 992tv在线成人免费观看 | 国内精品美女在线观看 | av一本久道久久波多野结衣 | 国内精品久久久久久久久久久 | 成人免费xyz网站 | 免费在线观看视频a | 在线之家免费在线观看电影 | 中文字幕在线精品 | 97国产精品 | 一区二区激情 | 亚洲欧美偷拍另类 | 国产69久久久欧美一级 | 成人9ⅰ免费影视网站 | 亚洲美女免费精品视频在线观看 | 五月激情姐姐 | 国产精品麻豆免费版 | 99精品国产aⅴ | 欧美va天堂va视频va在线 | 久久视频精品在线观看 | 免费视频一区 | 久久免费片| 成人黄色片免费 | 免费97视频| 国产一区二区在线观看免费 | 99视频在线观看免费 | www.xxx.性狂虐 | 国产96av| 久久尤物电影视频在线观看 | 久久久久久久久久久久久影院 | 成人毛片在线视频 | 国产一区在线视频观看 | 欧美a级一区二区 | 毛片永久新网址首页 | 亚洲闷骚少妇在线观看网站 | 99九九热只有国产精品 | 日日夜夜精品免费 | 久久99热精品这里久久精品 | 国产一级片观看 | 成人精品久久 | 伊人婷婷在线 | 国产成人精品在线 | 国产艹b视频 | 日韩三级视频在线看 | 亚洲va综合va国产va中文 | 国产高清精 | 成人在线视频在线观看 | 久久综合免费视频影院 | 亚洲欧美日韩国产精品一区午夜 | 欧美国产一区二区 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 美女中文字幕 | 国产精品午夜在线观看 | 国产高清在线看 | www久 | 国产看片免费 | 免费av小说| 99久久精品国产免费看不卡 | 色婷在线 | 97视频免费观看 | 国产日韩欧美视频在线观看 | 国产成年免费视频 | 精品国产亚洲一区二区麻豆 | 国产一区二区在线免费观看 | 在线视频免费观看 | 国产麻豆精品传媒av国产下载 | 免费影视大全推荐 | 丁香婷婷激情啪啪 | 91热在线 | 亚洲男男gaygay无套 | 久久爱影视i | 日韩久久精品一区二区三区下载 | 久久手机在线视频 | 激情视频91| 超碰精品在线观看 | 嫩草av影院| 国产成人无码AⅤ片在线观 日韩av不卡在线 | 久久综合影院 | 国产精品成人av电影 | 久久一级片 | 999成人国产 | 国产高清av在线播放 | 欧美一级片在线免费观看 | 免费在线观看成年人视频 | 天堂av在线 | 国产第一页精品 | 91精品国产99久久久久久红楼 | 五月天网页 | 丁香综合网 | 成人av资源在线 | 国精产品满18岁在线 | 免费看国产曰批40分钟 | 97超碰人人澡人人爱 | 不卡的av中文字幕 | 九九热免费在线视频 | 日韩电影在线观看一区二区 | 91精品一区二区在线观看 | 国产精品99久久久久久有的能看 | 少妇搡bbbb搡bbb搡aa | 免费久久久 | 麻豆观看| 日本九九视频 | 黄a网站 | 二区三区av| 91在线色| 国产999视频在线观看 | 久草视频在线免费看 | 深爱激情五月网 | 有码中文字幕在线观看 | 91系列在线观看 | 午夜三级大片 | 在线观看免费色 | 蜜桃视频成人在线观看 | 中文字幕免费观看 | 成人久久久久久久久久 | 日本资源中文字幕在线 | 91中文字幕网 | 日日躁你夜夜躁你av蜜 | 精品免费一区 | 亚洲国产精彩中文乱码av | 五月天伊人 | 国产99区| 激情久久久久久久久久久久久久久久 | 五月婷婷激情网 | 国产精品久久久久一区二区 | 99爱在线| 免费高清看电视网站 | 免费黄色a网站 | 顶级bbw搡bbbb搡bbbb | 亚州精品在线视频 | 精品伦理一区二区三区 | 超碰97人人射妻 | 中文字幕精品www乱入免费视频 | 国产午夜精品视频 | 美女福利视频在线 | 免费观看视频的网站 | 国产精品免费视频一区二区 | 人人狠狠综合久久亚洲 | 91视频xxxx| 91精品老司机久久一区啪 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 最新日韩中文字幕 | 国产系列精品av | 国产69精品久久久久久 | 国产91精品久久久久久 | 久久国产经典视频 | 激情久久小说 | 婷婷久久精品 | 亚洲一一在线 | 六月久久婷婷 | 欧美性爽爽 | 成人毛片一区 | 500部大龄熟乱视频 欧美日本三级 | 一级精品视频在线观看宜春院 | 午夜视频在线瓜伦 | 成人av高清在线观看 | 在线视频一区观看 | 久久爱www. | 99视频在线观看视频 | av成人在线播放 | 色婷婷国产精品 | 视频在线观看国产 | 丁香九月激情综合 | 69久久99精品久久久久婷婷 | 亚洲精品国内 | 亚洲自拍偷拍色图 | 中文字幕色播 | 人人爽人人乐 | 91丨九色丨高潮 | 激情视频一区二区三区 | 国产精品久久久久久模特 | 中文字幕在线网址 | 国产欧美三级 | 国产69精品久久app免费版 | 久久精品第一页 | 亚洲va天堂va欧美ⅴa在线 | 久久精品免费播放 | 国产精品丝袜在线 | 亚洲日本va在线观看 | 婷婷伊人五月 | 伊人天天狠天天添日日拍 | 国产一级91 | 日本巨乳在线 | 亚洲成人高清在线 | 91av在线电影 | 在线视频电影 | 麻豆播放 | 激情综合网婷婷 | 99久久这里有精品 | 手机成人在线 | 久久少妇av| 日韩视频一区二区 | 日韩欧美国产免费播放 | 精品在线一区二区 | 日韩影视精品 | 在线免费黄色片 | 国产精品18久久久久久不卡孕妇 | 久久97精品 | 精品国产人成亚洲区 | 国产97视频 |