欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java 超詳細(xì)講解數(shù)據(jù)結(jié)構(gòu)的應(yīng)用

 更新時(shí)間:2022年04月08日 10:23:59   作者:撩得Android一次心動  
數(shù)據(jù)結(jié)構(gòu)是計(jì)算機(jī)存儲、組織數(shù)據(jù)的方式。數(shù)據(jù)結(jié)構(gòu)是指相互之間存在一種或多種特定關(guān)系的數(shù)據(jù)元素的集合,讓我們一起來了解數(shù)據(jù)結(jié)構(gòu)是如何應(yīng)用的

一.bfs

bfs(廣度優(yōu)先搜索),類似二叉樹的層序遍歷,利用隊(duì)列完成。一般用于求最短路。

圖的最短路問題:

給定一個(gè)無向圖,每條邊的長度都是1。求1號點(diǎn)到x號點(diǎn)的最短距離。 頂點(diǎn)數(shù)n ?邊數(shù)為m

q次詢問 ?輸入x 輸出1到x的最短距離。 若1號點(diǎn)到x不連通,則輸出-1

二.雙端隊(duì)列

雙端隊(duì)列的應(yīng)用(區(qū)間翻轉(zhuǎn)):

對于長度為n的數(shù)組,給定一個(gè)長度為m的區(qū)間,區(qū)間初始位置為a[1]到a[m]。

3種操作:

  • 區(qū)間右移(最右端不會超過a[n])
  • 區(qū)間左移(最左端不會超過a[n])
  • 區(qū)間內(nèi)所有數(shù)翻轉(zhuǎn)。

q次操作后請你還原數(shù)組。

三.算法題

1.kotori和迷宮

難度??

知識點(diǎn):bfs

首先找到k字母,然后從k字母位置開始bfs。bfs過程中即可得到k到每個(gè)e的最短路程。(要注意走過的e不可繼續(xù)往下走)

題目描述:

kotori在一個(gè)n*m迷宮里,迷宮的最外層被巖漿淹沒,無法涉足,迷宮內(nèi)有k個(gè)出口。kotori只能上下左右四個(gè)方向移動。她想知道有多少出口是她能到達(dá)的,最近的出口離她有多遠(yuǎn)?

輸入描述:

第一行為兩個(gè)整數(shù)n和m,代表迷宮的行和列數(shù) (1≤n,m≤30)

后面緊跟著n行長度為m的字符串來描述迷宮。'k'代表kotori開始的位置,'.'代表道路,'*'代表墻壁,'e'代表出口。保證輸入合法。

輸出描述:

若有出口可以抵達(dá),則輸出2個(gè)整數(shù),第一個(gè)代表kotori可選擇的出口的數(shù)量,第二個(gè)代表kotori到最近的出口的步數(shù)。(注意,kotori到達(dá)出口一定會離開迷宮)

若沒有出口可以抵達(dá),則輸出-1。

示例1

輸入

6 8

e.*.*e.*

.**.*.*e

..*k**..

***.*.e*

.**.*.**

*......e

輸出

2 7

說明

可供選擇坐標(biāo)為[4,7]和[6,8],到kotori的距離分別是8和7步。

import java.util.*;
import java.io.*;
public class Main{
  public static void main(String[] args) throws IOException{
    BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));
    String[] s1 = bf.readLine().split(" ");
    int n = Integer.parseInt(s1[0]);
    int m = Integer.parseInt(s1[1]);
    //建立地圖、標(biāo)記圖
    char[][] maze = new char[n][m];
    boolean[][] visited = new boolean[n][m];
    //紀(jì)錄步數(shù)
    int[][] dis = new int[n][m];
    //紀(jì)錄初始的坐標(biāo)
    int ki = 0, kj = 0;
    for(int i = 0; i < n; i++){
      String s = bf.readLine();
      for(int j = 0; j < m; j++){
         dis[i][j] = Integer.MAX_VALUE;
         char c = s.charAt(j);
         maze[i][j] = c;
         if(c == 'k'){
          ki = i;
          kj = j;
        }
      }
    }
     
    int count = 0, min = Integer.MAX_VALUE;
    Queue<Integer> queue = new ArrayDeque<>();
    //二維數(shù)組的性質(zhì),保存了坐標(biāo),并且節(jié)省了空間
    queue.add(ki * m + kj);
    visited[ki][kj] = true;
    dis[ki][kj]= 0;
    while(!queue.isEmpty()){
      int temp = queue.poll();
      int tempi = temp / m, tempj = temp % m;
      //支持八個(gè)方向的移動或者不移動(但是因?yàn)镸ath.abs(i - j) == 1限定了絕對值為1,所以變成了四個(gè)方向)
      for(int i = -1; i <= 1; i++){
        for(int j = -1; j <= 1; j++){
          if(Math.abs(i - j) == 1 && tempi + i >= 0 && tempi + i < n && tempj + j >= 0 && tempj + j < m && !visited[tempi + i][tempj + j]){
            if(maze[tempi + i][tempj + j] == '.'){
              visited[tempi + i][tempj + j] = true;
              dis[tempi + i][tempj + j] = dis[tempi][tempj] + 1;
              queue.add((tempi + i) * m + (tempj + j));
            }
            if(maze[tempi + i][tempj + j] == 'e'){
              visited[tempi + i][tempj + j] = true;
              dis[tempi + i][tempj + j] = dis[tempi][tempj] + 1;
              min = Math.min(min, dis[tempi][tempj] + 1);
              count++;
            }
          }
        }
      } 
    }
    if(count == 0) System.out.print(-1);
    else System.out.print(count + " " + min);
  }
}

思考:隊(duì)列是怎么實(shí)現(xiàn)bfs的?

1.起始點(diǎn)入隊(duì)-->2.將起始點(diǎn)四個(gè)方向的可達(dá)點(diǎn)入隊(duì)-->3.起始點(diǎn)出隊(duì)。以此循序依次訪問隊(duì)列中的元素。

2.小紅找紅點(diǎn)

難度???

知識點(diǎn):bfs,多源最短路

多源最短路的求法:在bfs開始之前將所有點(diǎn)都扔進(jìn)隊(duì)列,然后開始bfs即可。

題目描述:

小紅拿到了一張無向圖,有 n?個(gè)頂點(diǎn)和?m?條邊。每條邊的長度為 1 。?

小紅給一些頂點(diǎn)染成了紅色。她想知道,對于每個(gè)頂點(diǎn),到附近最近的紅色點(diǎn)的距離為多少?

輸入描述:

第一行輸出兩個(gè)正整數(shù) n 和 m ,用空格隔開。分別代表頂點(diǎn)數(shù)和邊數(shù)。

第二行輸入一個(gè)長度為 n 的字符串,代表每個(gè)頂點(diǎn)的染色情況。第?i 個(gè)字符為 'R' 代表被染成紅色,為 'W' 代表未被染色。

接下來的?m 行,每行兩個(gè)正整數(shù) x 和?y ,代表?x 和?y 有一條無向邊相連。

不保證圖是整體連通的。不保證沒有重邊和自環(huán)。

1<=n,m<=10^5

輸出描述:

輸出一行 n 個(gè)整數(shù),代表從?1 到 n 每個(gè)頂點(diǎn)到最近的紅色頂點(diǎn)的距離。若對于某點(diǎn)而言無論如何都走不到紅色頂點(diǎn),則輸出 -1 。

示例1:

輸入

5 5

RWWRW

1 2

3 3

1 2

2 5

1 4

輸出

0 1 -1 0 2

說明

樣例的圖如上所示。

import java.util.*;
import java.io.*;
 
public class Main{
    static ArrayList<Integer>[] g;
    static String[] strings;
    static int[] visited;
    static int[] dis;
 
    public static void main(String[] args) throws Exception {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String[] firstLine = br.readLine().split(" ");
        int n = Integer.parseInt(firstLine[0]);
        int m = Integer.parseInt(firstLine[1]);
        g = new ArrayList[n+1];
        visited = new int[n+1];
        dis= new int[n+1];
        for (int i=1;i<n+1;i++) {
            g[i] = new ArrayList<Integer>();
        }
        //一個(gè)字符一個(gè)字符的讀取
        strings = br.readLine().split("");
        for (int i=0;i<m;i++) {
            //描繪雙向圖
            String[] temp = br.readLine().split(" ");
            int x = Integer.parseInt(temp[0]);
            int y = Integer.parseInt(temp[1]);
            g[x].add(y);
            g[y].add(x);
        }
        //g[x]代表當(dāng)前點(diǎn) g[x].get(i)代表所連的線
        Queue<Integer> queue = new ArrayDeque<>();
        for(int i=1;i<=n;i++){
            if(strings[i-1].equals("R")){
                queue.add(i);
                visited[i]=1;
            }
        }
        while(!queue.isEmpty()){
            int temp=queue.remove();
            for(int i=0;i<g[temp].size();i++){
                if(visited[g[temp].get(i)]==0){
                    visited[g[temp].get(i)]=1;
                    dis[g[temp].get(i)]=dis[temp]+1;
                    queue.add(g[temp].get(i));
                }
            }
        }
        for(int i=1;i<=n;i++){
            if(visited[i]==0)System.out.print("-1 ");
            else System.out.print(dis[i]+" ");
        }
    }
}

對照上一章的案例:小紅點(diǎn)點(diǎn)點(diǎn)結(jié)合理解。? 分別使用的dfs和bfs。

本題思想:先將紅色的所有點(diǎn)都入隊(duì)列,然后bfs。

這是一種逆向思維:不是所謂的從編號開始,并且所有走過的都不能在走了。

3.小紅玩數(shù)組?

難度????

知識點(diǎn):雙端隊(duì)列

用一個(gè)雙端隊(duì)列來模擬過程,用一個(gè)變量來標(biāo)記雙端隊(duì)列是否翻轉(zhuǎn)過。

示例1:

輸入

6 4

1 5 4 6 2 8

5

21323

輸出

4 6 2 1 5 8

import java.io.*;
import java.util.*;
public class Main{
    static Deque<Integer> workQueue;
    public static void main(String[] args)throws IOException{
        BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
        PrintWriter pw=new PrintWriter(System.out);
        String[] firstLine=br.readLine().split(" ");
        int total=Integer.parseInt(firstLine[0]);
        int size=Integer.parseInt(firstLine[1]);
        int[] arr=new int[total];
        String[] secondLine=br.readLine().split(" ");
        for(int i=0;i<total;i++){
            arr[i]=Integer.parseInt(secondLine[i]);
        }
        int L=0;
        int R=size-1;
        workQueue=new LinkedList<>();
        for(int i=0;i<size;i++){
            workQueue.offerLast(arr[i]);
        }
        int times=Integer.parseInt(br.readLine());
        String tries=br.readLine();
        int is=0;//0代表沒有翻轉(zhuǎn)!
        for(int i=0;i<times;i++){
            if(tries.charAt(i)=='1'){
                if(R==arr.length-1)
                    continue;
                R++;
                if(is==0){
 
                    workQueue.offerLast(arr[R]);
                    int tmp=workQueue.pollFirst();
                    arr[L]=tmp;
 
                }else{
 
                    workQueue.offerFirst(arr[R]);
                    int tmp=workQueue.pollLast();
                    arr[L]=tmp;
 
                }
                L++;
            }else if(tries.charAt(i)=='2'){
                if(L==0)
                    continue;
                L--;
                if(is==0){
                    workQueue.offerFirst(arr[L]);
 
                    arr[R]=workQueue.pollLast();
 
                }else{
 
                    workQueue.offerLast(arr[L]);
                    arr[R]=workQueue.pollFirst();
 
 
                }
                R--;
            }else{
                is=1-is;
            }
        }
        for(int i=0;i<L;i++){
            pw.print(arr[i]+" ");
        }
        if(is==0){
            while(!workQueue.isEmpty()) {
                pw.print(workQueue.pollFirst() + " ");
            }
        }else{
            while(!workQueue.isEmpty()) {
                pw.print(workQueue.pollLast() + " ");
            }
        }
        for(int i=R+1;i<arr.length;i++){
            pw.print(arr[i]+" ");
        }
        pw.flush();
 
    }
}

到此這篇關(guān)于Java 超詳細(xì)講解數(shù)據(jù)結(jié)構(gòu)的應(yīng)用的文章就介紹到這了,更多相關(guān)Java 數(shù)據(jù)結(jié)構(gòu)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java中Maven項(xiàng)目導(dǎo)出jar包配置的示例代碼

    Java中Maven項(xiàng)目導(dǎo)出jar包配置的示例代碼

    這篇文章主要介紹了Java中Maven項(xiàng)目導(dǎo)出jar包配置的示例代碼,需要的朋友可以參考下
    2018-11-11
  • Java反射中java.beans包學(xué)習(xí)總結(jié)

    Java反射中java.beans包學(xué)習(xí)總結(jié)

    本篇文章通過學(xué)習(xí)Java反射中java.beans包,吧知識點(diǎn)做了總結(jié),并把相關(guān)內(nèi)容做了關(guān)聯(lián),對此有需要的朋友可以學(xué)習(xí)參考下。
    2018-02-02
  • Java實(shí)現(xiàn)整數(shù)的逆序輸出的三種方法

    Java實(shí)現(xiàn)整數(shù)的逆序輸出的三種方法

    這篇文章主要介紹了Java實(shí)現(xiàn)整數(shù)的逆序輸出的三種方法,第一種是無限制整數(shù)的逆序輸出,第二種是非負(fù)整數(shù)的逆序輸出,第三種是非特殊情況的逆序輸出,每種方法給大家講解的非常詳細(xì)需要的朋友可以參考下
    2022-11-11
  • Java中List轉(zhuǎn)字符串的5種方法解析

    Java中List轉(zhuǎn)字符串的5種方法解析

    在Java中將一個(gè)List轉(zhuǎn)換為字符串有多種方法,下面這篇文章主要給大家介紹了關(guān)于Java中List轉(zhuǎn)字符串的5種方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • JDK源碼之PriorityQueue解析

    JDK源碼之PriorityQueue解析

    這篇文章主要為大家詳細(xì)介紹了JDK源碼之PriorityQueue,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • Spring Boot如何通過CORS處理跨域問題

    Spring Boot如何通過CORS處理跨域問題

    這篇文章主要介紹了Spring Boot如何通過CORS處理跨域問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • Java緩存框架之Caffeine源碼解析

    Java緩存框架之Caffeine源碼解析

    這篇文章主要介紹了Java緩存框架之Caffeine源碼解析,Caffeine?是一個(gè)基于Java?8的高性能本地緩存框架,其結(jié)構(gòu)和?Guava?Cache?基本一樣,api也一樣,基本上很容易就能替換,需要的朋友可以參考下
    2023-11-11
  • springboot bean循環(huán)依賴實(shí)現(xiàn)以及源碼分析

    springboot bean循環(huán)依賴實(shí)現(xiàn)以及源碼分析

    最近在使用Springboot做項(xiàng)目的時(shí)候,遇到了一個(gè)循環(huán)依賴的 問題,所以下面這篇文章主要給大家介紹了關(guān)于springboot bean循環(huán)依賴實(shí)現(xiàn)以及源碼分析的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • Spring Boot如何讀取自定義外部屬性詳解

    Spring Boot如何讀取自定義外部屬性詳解

    這篇文章主要給大家介紹了關(guān)于Spring Boot如何讀取自定義外部屬性的相關(guān)資料,這個(gè)功能實(shí)現(xiàn)介紹的很詳細(xì),需要的朋友可以參考下
    2021-05-05
  • 使用Java實(shí)現(xiàn)查找并移除字符串中的Emoji

    使用Java實(shí)現(xiàn)查找并移除字符串中的Emoji

    Emoji 實(shí)際上是 UTF-8 (Unicode) 字符集上的特殊字符,這篇文章主要介紹了如何使用Java實(shí)現(xiàn)查找并移除字符串中的Emoji,感興趣的可以了解下
    2024-03-03

最新評論