国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

程序開發中常用的十種算法,你用過幾種?

開發 后端
當編寫程序時,了解和使用不同的算法對解決問題至關重要。以下是C#中常用的10種算法,每個算法都伴隨著示例代碼和詳細說明。

1、冒泡排序 (Bubble Sort):

冒泡排序是一種簡單的比較排序算法,它多次遍歷數組,將較大的元素逐漸浮動到數組的末尾。

public static void BubbleSort(int[] arr)
{
    int n = arr.Length;
    for (int i = 0; i < n - 1; i++)
    {
        for (int j = 0; j < n - i - 1; j++)
        {
            if (arr[j] > arr[j + 1])
            {
                int temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}

2、快速排序 (Quick Sort):

快速排序是一種高效的分治排序算法,它通過選擇一個基準元素并將數組分為較小和較大的兩部分來進行排序。

public static void QuickSort(int[] arr, int low, int high)
{
    if (low < high)
    {
        int partitionIndex = Partition(arr, low, high);
        QuickSort(arr, low, partitionIndex - 1);
        QuickSort(arr, partitionIndex + 1, high);
    }
}

public static int Partition(int[] arr, int low, int high)
{
    int pivot = arr[high];
    int i = low - 1;

    for (int j = low; j < high; j++)
    {
        if (arr[j] < pivot)
        {
            i++;
            int temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
        }
    }

    int swap = arr[i + 1];
    arr[i + 1] = arr[high];
    arr[high] = swap;

    return i + 1;
}

3、合并排序 (Merge Sort):

合并排序是一種穩定的分治排序算法,它將數組分成兩半,分別排序后再合并。

public static void MergeSort(int[] arr)
{
    int n = arr.Length;
    if (n > 1)
    {
        int mid = n / 2;
        int[] left = new int[mid];
        int[] right = new int[n - mid];

        for (int i = 0; i < mid; i++)
            left[i] = arr[i];
        for (int i = mid; i < n; i++)
            right[i - mid] = arr[i];

        MergeSort(left);
        MergeSort(right);

        int i = 0, j = 0, k = 0;
        while (i < mid && j < (n - mid))
        {
            if (left[i] < right[j])
                arr[k++] = left[i++];
            else
                arr[k++] = right[j++];
        }
        while (i < mid)
            arr[k++] = left[i++];
        while (j < (n - mid))
            arr[k++] = right[j++];
    }
}

4、二分查找 (Binary Search):

二分查找是一種高效的查找算法,它要求在有序數組中查找特定元素。

public static int BinarySearch(int[] arr, int target)
{
    int low = 0, high = arr.Length - 1;
    while (low <= high)
    {
        int mid = (low + high) / 2;
        if (arr[mid] == target)
            return mid;
        else if (arr[mid] < target)
            low = mid + 1;
        else
            high = mid - 1;
    }
    return -1;
}

5、深度優先搜索 (Depth-First Search, DFS):

DFS 是一種圖遍歷算法,它從起始節點開始,沿著路徑盡可能深入,然后返回并繼續搜索。

using System;
using System.Collections.Generic;

public class Graph
{
    private int V;
    private List<int>[] adj;

    public Graph(int v)
    {
        V = v;
        adj = new List<int>[v];
        for (int i = 0; i < v; i++)
            adj[i] = new List<int>();
    }

    public void AddEdge(int v, int w)
    {
        adj[v].Add(w);
    }

    public void DFS(int v)
    {
        bool[] visited = new bool[V];
        DFSUtil(v, visited);
    }

    private void DFSUtil(int v, bool[] visited)
    {
        visited[v] = true;
        Console.Write(v + " ");

        foreach (var n in adj[v])
        {
            if (!visited[n])
                DFSUtil(n, visited);
        }
    }
}

6、廣度優先搜索 (Breadth-First Search, BFS):

BFS 是一種圖遍歷算法,它從起始節點開始,逐層遍歷,先訪問所有相鄰的節點,然后再逐層擴展。

using System;
using System.Collections.Generic;

public class Graph
{
    private int V;
    private List<int>[] adj;

    public Graph(int v)
    {
        V = v;
        adj = new List<int>[v];
        for (int i = 0; i < v; i++)
            adj[i] = new List<int>();
    }

    public void AddEdge(int v, int w)
    {
        adj[v].Add(w);
    }

    public void BFS(int s)
    {
        bool[] visited = new bool[V];

        Queue<int> queue = new Queue<int>();
        visited[s] = true;
        queue.Enqueue(s);

        while (queue.Count != 0)
        {
            s = queue.Dequeue();
            Console.Write(s + " ");

            foreach (var n in adj[s])
            {
                if (!visited[n])
                {
                    visited[n] = true;
                    queue.Enqueue(n);
                }
            }
        }
    }
}

7、Dijkstra算法:

Dijkstra算法是一種用于查找圖中最短路徑的算法。

public class Dijkstra
{
    private static int V = 9;

    private int MinDistance(int[] dist, bool[] sptSet)
    {
        int min = int.MaxValue;
        int minIndex = 0;

        for (int v = 0; v < V; v++)
        {
            if (!sptSet[v] && dist

[v] <= min)
            {
                min = dist[v];
                minIndex = v;
            }
        }

        return minIndex;
    }

    private void PrintSolution(int[] dist)
    {
        Console.WriteLine("Vertex \t Distance from Source");
        for (int i = 0; i < V; i++)
        {
            Console.WriteLine(i + " \t " + dist[i]);
        }
    }

    public void FindShortestPath(int[,] graph, int src)
    {
        int[] dist = new int[V];
        bool[] sptSet = new bool[V];

        for (int i = 0; i < V; i++)
        {
            dist[i] = int.MaxValue;
            sptSet[i] = false;
        }

        dist[src] = 0;

        for (int count = 0; count < V - 1; count++)
        {
            int u = MinDistance(dist, sptSet);

            sptSet[u] = true;

            for (int v = 0; v < V; v++)
            {
                if (!sptSet[v] && graph[u, v] != 0 && dist[u] != int.MaxValue && dist[u] + graph[u, v] < dist[v])
                {
                    dist[v] = dist[u] + graph[u, v];
                }
            }
        }

        PrintSolution(dist);
    }
}

8、最小生成樹 (Minimum Spanning Tree, MST) - Prim算法:

Prim算法用于找到圖的最小生成樹,它從一個初始頂點開始,逐漸擴展生成樹。

public class PrimMST
{
    private static int V = 5;

    private int MinKey(int[] key, bool[] mstSet)
    {
        int min = int.MaxValue;
        int minIndex = 0;

        for (int v = 0; v < V; v++)
        {
            if (!mstSet[v] && key[v] < min)
            {
                min = key[v];
                minIndex = v;
            }
        }

        return minIndex;
    }

    private void PrintMST(int[] parent, int[,] graph)
    {
        Console.WriteLine("Edge \t Weight");
        for (int i = 1; i < V; i++)
        {
            Console.WriteLine(parent[i] + " - " + i + " \t " + graph[i, parent[i]]);
        }
    }

    public void FindMST(int[,] graph)
    {
        int[] parent = new int[V];
        int[] key = new int[V];
        bool[] mstSet = new bool[V];

        for (int i = 0; i < V; i++)
        {
            key[i] = int.MaxValue;
            mstSet[i] = false;
        }

        key[0] = 0;
        parent[0] = -1;

        for (int count = 0; count < V - 1; count++)
        {
            int u = MinKey(key, mstSet);

            mstSet[u] = true;

            for (int v = 0; v < V; v++)
            {
                if (graph[u, v] != 0 && !mstSet[v] && graph[u, v] < key[v])
                {
                    parent[v] = u;
                    key[v] = graph[u, v];
                }
            }
        }

        PrintMST(parent, graph);
    }
}

9、最小生成樹 (Minimum Spanning Tree, MST) - Kruskal算法:

Kruskal算法也用于找到圖的最小生成樹,它基于邊的權重排序。

using System;
using System.Collections.Generic;

public class Graph
{
    private int V, E;
    private List<Edge> edges;

    public Graph(int v, int e)
    {
        V = v;
        E = e;
        edges = new List<Edge>(e);
    }

    public void AddEdge(int src, int dest, int weight)
    {
        edges.Add(new Edge(src, dest, weight));
    }

    public void KruskalMST()
    {
        edges.Sort();

        int[] parent = new int[V];
        int[] rank = new int[V];

        for (int i = 0; i < V; i++)
        {
            parent[i] = i;
            rank[i] = 0;
        }

        int i = 0;
        int e = 0;

        List<Edge> mst = new List<Edge>();

        while (e < V - 1)
        {
            Edge nextEdge = edges[i++];
            int x = Find(parent, nextEdge.src);
            int y = Find(parent, nextEdge.dest);

            if (x != y)
            {
                mst.Add(nextEdge);
                Union(parent, rank, x, y);
                e++;
            }
        }

        Console.WriteLine("Edges in Minimum Spanning Tree:");
        foreach (var edge in mst)
        {
            Console.WriteLine($"{edge.src} - {edge.dest} with weight {edge.weight}");
        }
    }

    private int Find(int[] parent, int i)
    {
        if (parent[i] == i)
            return i;
        return Find(parent, parent[i]);
    }

    private void Union(int[] parent, int[] rank, int x, int y)
    {
        int xRoot = Find(parent, x);
        int yRoot = Find(parent, y);

        if (rank[xRoot] < rank[yRoot])
            parent[xRoot] = yRoot;
        else if (rank[xRoot] > rank[yRoot])
            parent[yRoot] = xRoot;
        else
        {
            parent[yRoot] = xRoot;
            rank[xRoot]++;
        }
    }
}

public class Edge : IComparable<Edge>
{
    public int src, dest, weight;

    public Edge(int src, int dest, int weight)
    {
        this.src = src;
        this.dest = dest;
        this.weight = weight;
    }

    public int CompareTo(Edge other)
    {
        return weight - other.weight;
    }
}

10、Floyd-Warshall算法是一種用于解決所有點對最短路徑的動態規劃算法。

下面是C#中的Floyd-Warshall算法的實現示例:

using System;

class FloydWarshall
{
    private static int INF = int.MaxValue; // 代表無窮大的值

    public static void FindShortestPath(int[,] graph)
    {
        int V = graph.GetLength(0);

        // 創建一個二維數組dist,用于保存最短路徑的長度
        int[,] dist = new int[V, V];

        // 初始化dist數組
        for (int i = 0; i < V; i++)
        {
            for (int j = 0; j < V; j++)
            {
                dist[i, j] = graph[i, j];
            }
        }

        // 逐個頂點考慮,如果經過k頂點路徑比原路徑短,就更新dist數組
        for (int k = 0; k < V; k++)
        {
            for (int i = 0; i < V; i++)
            {
                for (int j = 0; j < V; j++)
                {
                    if (dist[i, k] != INF && dist[k, j] != INF
                        && dist[i, k] + dist[k, j] < dist[i, j])
                    {
                        dist[i, j] = dist[i, k] + dist[k, j];
                    }
                }
            }
        }

        // 輸出最短路徑矩陣
        Console.WriteLine("最短路徑矩陣:");
        for (int i = 0; i < V; i++)
        {
            for (int j = 0; j < V; j++)
            {
                if (dist[i, j] == INF)
                    Console.Write("INF\t");
                else
                    Console.Write(dist[i, j] + "\t");
            }
            Console.WriteLine();
        }
    }

    static void Main(string[] args)
    {
        int V = 4; // 頂點數
        int[,] graph = {
            {0, 5, INF, 10},
            {INF, 0, 3, INF},
            {INF, INF, 0, 1},
            {INF, INF, INF, 0}
        };

        FindShortestPath(graph);
    }
}

在這個示例中,我們使用Floyd-Warshall算法來計算給定圖的最短路徑矩陣。該算法通過考慮逐個中間頂點k,不斷更新最短路徑矩陣dist。最終,我們可以獲得所有點對之間的最短路徑長度。

責任編輯:姜華 來源: 今日頭條
相關推薦

2023-05-17 12:33:11

AI人工智能

2023-11-02 08:32:11

機器學習人工智能

2022-04-17 23:09:07

深度學習人工智能芯片

2022-08-26 16:21:47

數據分析工具運營

2011-05-30 15:07:58

計算機語言

2024-10-30 16:39:45

2025-04-25 07:10:00

GenAIAI工具人工智能

2016-10-21 19:44:08

數據科學家算法

2022-09-25 23:34:42

算法回歸算法機器學習

2022-10-25 15:55:13

2022-02-14 22:04:50

瀏覽器Observer監聽

2019-10-08 09:00:00

MySQL數據庫

2022-02-21 23:12:21

軟件開發網絡安全互聯網

2025-06-16 08:22:23

2019-07-22 13:39:59

Python編輯器開發

2023-11-29 14:34:15

機器學習統計學

2022-07-29 10:31:33

算法Python

2021-07-02 21:53:23

物聯網開發編程語言開發

2024-11-13 13:20:44

2022-03-28 20:57:31

私有屬性class屬性和方法
點贊
收藏

51CTO技術棧公眾號

欧美亚洲视频在线观看| 日韩午夜在线影院| 国产精品免费小视频| 不卡av免费观看| 国产偷国产偷精品高清尤物| 超碰在线97av| 国产精品亚洲欧美日韩一区在线| 欧美色videos| 国产精品igao| 国产综合成人久久大片91| 91在线观看免费高清| 一级欧美视频| 亚洲国产精品高清久久久| 亚洲伦理在线| 欧美激情中文字幕一区二区| 亚洲色婷婷久久精品av蜜桃| 亚洲激情影院| 国产日韩欧美在线播放| 操欧美女人视频| 亚洲欧美精品suv| 免费黄色网页在线观看| 亚洲国产精品久久久久秋霞影院| 久操网在线观看| 日韩中文字幕av电影| 亚洲综合日韩在线| 亚洲v天堂v手机在线| 上原亚衣av一区二区三区| av电影院在线看| 欧美午夜精品一区| 视频黄页在线| 国产精品国产三级国产aⅴ中文| 国产成人亚洲综合无码| 男人的天堂久久精品| 国内一区二区在线视频观看| 日韩综合精品| 国产大片精品免费永久看nba| 日韩在线网址| 欧美成人精品h版在线观看| av成人亚洲| 在线日韩欧美视频| 亚洲伦乱视频| 亚洲欧美成人在线| 三级在线看中文字幕完整版| 欧美欧美午夜aⅴ在线观看| 成人激情电影在线看| 欧美天堂亚洲电影院在线播放| 韩国中文免费在线视频| 色哟哟国产精品免费观看| 能在线看的av| 欧美在线你懂的| 九色在线视频| 欧美日韩精品欧美日韩精品一| www.亚洲免费| 欧美军同video69gay| 超碰porn在线| 亚洲国产精品va在线观看黑人| 超碰在线视屏| 丝袜美腿亚洲一区二区| 日韩成人视屏| 91国语精品自产拍在线观看性色 | 亚洲第一福利一区| 最新国产在线视频| 在线观看日韩精品| 最爽无遮挡行房视频在线| 亚洲成avwww人| 国产欧美在线观看免费| 久久久久久国产精品| 精品av一区二区| 国产精品香蕉视屏| 精品一区二区国语对白| av免费观看大全| 中文字幕制服丝袜成人av | 久久精品亚洲94久久精品| 一区二区三区四区视频免费观看| 4p变态网欧美系列| 欧美va天堂在线| 亚洲免费在线精品一区| aaa国产一区| 一二三区高清| 欧美不卡一区二区三区四区| 亚洲伦理网站| 国a精品视频大全| 伊人色**天天综合婷婷| 亚洲在线播放电影| 国产精品国产自产拍高清av| 国产乱视频在线观看| 亚洲精品一区av在线播放| 精品福利一区| 欧美精品一区二区三区在线四季| 国产成人免费视频精品含羞草妖精| 污污的网站18| 欧美另类久久久品| 欧洲亚洲精品| 91在线播放国产| 国产成人免费在线| 小水嫩精品福利视频导航| 亚洲国产精品va在看黑人| 美女一区2区| 欧美日韩天天操| 国产精品视频一区二区三区不卡| 日本中文字幕在线2020| 欧美xxxx18性欧美| 国产精品丝袜xxxxxxx| 成人在线观看a| 欧美欧美午夜aⅴ在线观看| 北条麻妃在线一区二区免费播放 | 波多野吉衣av| 亚洲成人中文字幕| 国产欧美一区| 肉大捧一出免费观看网站在线播放| 亚洲另类一区二区| 澳门成人av网| 91沈先生播放一区二区| 久久久久久久久久久99999| 综合图区亚洲| 国产精品久久久久久久午夜| 国产麻豆成人传媒免费观看| 青青国产在线| 精品综合久久久久久97| 丝瓜av网站精品一区二区| 传媒在线观看| 中文字幕亚洲二区| 国产精品美女久久久浪潮软件| 4虎在线播放1区| 在线视频国产日韩| 美女黄网久久| 天堂中文字幕在线| 欧美日韩国产成人在线观看| 美女视频黄免费的久久 | 日韩一区二区精品葵司在线| 综合综合综合综合综合网| 麻豆tv在线播放| 日韩女优毛片在线| 亚洲mv大片欧洲mv大片| 啊啊啊好爽视频| 欧美激情欧美激情在线五月| 国产福利精品一区| 变态调教一区二区三区| 黄色99视频| 一本大道久久a久久精二百| 中文字幕av一区二区三区人| 久草在在线视频| 色爱精品视频一区| 国产成+人+日韩+欧美+亚洲| 成年网站在线视频网站| 欧美一区1区三区3区公司 | 视频一区在线观看| 久久精品99国产| 国产视频欧美视频| 久久先锋资源| 黄色精品在线观看| 国产麻豆乱码精品一区二区三区 | 日本欧美电影在线观看| 国产高清在线精品一区二区三区| 一区二区三区欧美日韩| 亚洲精品3区| 成年人视频网站| 国模吧一区二区| 欧美国产日韩一二三区| 亚洲日本视频在线| 国内外免费激情视频| 久久亚洲国产精品| 91麻豆精东视频| 日韩成人免费av| 日本韩国欧美在线观看| 日韩视频精品在线| 久久久久成人黄色影片| 欧美日韩国产一区二区在线观看| 免费在线观看亚洲视频 | 久久福利影视| av免费在线观| 视频一区免费观看| 亚洲韩国青草视频| 韩国精品一区二区| 日本高清不卡一区二区三区视频 | 欧美影视一区二区| 日韩美一区二区三区| 日本aⅴ免费视频一区二区三区| 精品精品导航| 超碰97在线看| 久久久成人精品视频| 国产欧美日韩卡一| 成人直播大秀| 老司机在线视频二区| 亚洲欧美日韩在线综合| 国产一区二区三区直播精品电影 | 大肉大捧一进一出好爽视频| 久热精品视频在线免费观看| 综合亚洲深深色噜噜狠狠网站| 欧美日韩第一| 一级毛片视频在线观看| 国产又粗又大又爽的视频| 欧美韩日一区二区| 欧美午夜影院在线视频| 免播放器亚洲一区| 日韩激情欧美| 毛片网站在线| 男人天堂手机在线视频| 欧洲精品毛片网站| 日韩你懂的电影在线观看|