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

c#實現(xiàn)哈夫曼樹算法

 更新時間:2022年06月17日 08:39:06   作者:天方  
這篇文章介紹了c#實現(xiàn)哈夫曼樹的實例代碼,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

今天看了一下數(shù)據(jù)結(jié)構(gòu),一個練習就是構(gòu)建哈夫曼樹,就順手用C#寫了一個。

static void Main(string[] args)
{
    var numbers = new int[] { 1, 3, 3, 3, 5, 5, 5, 5, 5, 7, 7, 7, 7, 7, 7, 7 };

    var treeList = new List<HuffmanTree>();
    treeList.AddRange(from n in numbers
                     group n by n into g
                     select new HuffmanTree { Value = g.Key, Degree = g.Count() });

    while (treeList.Count>1)
    {
        var sel = from i in treeList
                 orderby i.Degree ascending
                 select i;
        var min = sel.Take(2).ToArray();

        treeList.Add(new HuffmanTree { Left = min[0], Right = min[1], Degree = min[0].Degree + min[1].Degree });

        treeList.Remove(min[0]);
        treeList.Remove(min[1]);
    }
}

class HuffmanTree
{
    public HuffmanTree Left { get; set; }
    public HuffmanTree Right { get; set; }

    public int Value { get; set; }
    public int Degree { get; set; }

    public override string ToString()
    {
        return Value + " " + Degree;
    }
}

我用LINQ很直接的寫出了這段代碼,寫完后我都覺得有點吃驚:基本上每一步都只用了一句話完成了,并且都是自注釋的,寫得讓人感覺十分流暢。

雖然這個實現(xiàn)運行效率不高,還有一些可以優(yōu)化的地方,但我卻非常喜歡這種簡潔、高效(開發(fā)效率)的代碼,看著十分舒服。這也是C#的一個十分讓我入迷的地方->優(yōu)雅:可以將心中的想法快速用代碼表現(xiàn)出來,高屋建瓴,一氣呵成,不必于在拘泥于細節(jié)。很多時候,在細節(jié)實現(xiàn)苦苦琢磨的時往往會忘記最開始突發(fā)的靈感和編程的樂趣。

同時我想起了前幾天發(fā)的一個算法練習的帖子,雖然用C#可以在20行之內(nèi)實現(xiàn),但一大片經(jīng)驗豐富的程序員在4個小時之內(nèi)用C語言(不能使用任何庫)卻無法完成。我想,對那同一個題目,用20行和用200行實現(xiàn)的時候的人心情是截然不同的吧。

到此這篇關(guān)于c#實現(xiàn)哈夫曼樹的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C#圖片壓縮的實現(xiàn)方法

    C#圖片壓縮的實現(xiàn)方法

    一般在web應用中,對客戶端提交上來的圖片肯定需要進行壓縮的。尤其是比較大的圖片,如果不經(jīng)過壓縮會導致頁面變的很大,打開速度比較慢,當然了如果是需要高質(zhì)量的圖片也得需要生產(chǎn)縮略圖。
    2013-02-02
  • c#中單例類與靜態(tài)類的區(qū)別以及使用場景

    c#中單例類與靜態(tài)類的區(qū)別以及使用場景

    這篇文章主要給大家介紹了關(guān)于c#中單例類與靜態(tài)類的區(qū)別以及使用場景的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • 基于C#中IDisposable與IEnumerable、IEnumerator的應用

    基于C#中IDisposable與IEnumerable、IEnumerator的應用

    本篇文章小編為大家介紹,基于C#中IDisposable與IEnumerable、IEnumerator的應用,需要的朋友參考下
    2013-04-04
  • C#操作串口通信協(xié)議Modbus的常用方法介紹

    C#操作串口通信協(xié)議Modbus的常用方法介紹

    這篇文章介紹了C#操作串口通信協(xié)議Modbus的常用方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-05-05
  • C#中括號強轉(zhuǎn)、as、is區(qū)別詳解

    C#中括號強轉(zhuǎn)、as、is區(qū)別詳解

    本文主要介紹了C#中括號強轉(zhuǎn)、as、is區(qū)別詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-02-02
  • C#使用throw和throw?ex拋出異常的區(qū)別介紹

    C#使用throw和throw?ex拋出異常的區(qū)別介紹

    這篇文章介紹了C#使用throw和throw?ex拋出異常的區(qū)別,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10
  • C#異常處理中try和catch語句及finally語句的用法示例

    C#異常處理中try和catch語句及finally語句的用法示例

    這篇文章主要介紹了C#異常處理中try和catch語句及finally語句的用法示例,finally語句的使用涉及到了C#的垃圾回收特性,需要的朋友可以參考下
    2016-02-02
  • C#實現(xiàn)寫入文本文件內(nèi)容的方法

    C#實現(xiàn)寫入文本文件內(nèi)容的方法

    這篇文章主要介紹了C#實現(xiàn)寫入文本文件內(nèi)容的方法,涉及C#針對文本文件的判斷、創(chuàng)建及寫入等相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-07-07
  • 詳解Unity地面檢測方案

    詳解Unity地面檢測方案

    本文主要介紹了Unity地面檢測方案,感興趣的同學,可以參考下,并且親自實驗一下。
    2021-05-05
  • C#中Try-Catch語句真的影響程序性能嗎?

    C#中Try-Catch語句真的影響程序性能嗎?

    這篇文章主要介紹了C#中Try-Catch語句真的影響程序性能嗎?本文結(jié)合IL分析Try-Catch語句的性能問題,需要的朋友可以參考下
    2015-06-06

最新評論