網站首頁 編程語言 正文
今天看了一下數據結構,一個練習就是構建哈夫曼樹,就順手用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很直接的寫出了這段代碼,寫完后我都覺得有點吃驚:基本上每一步都只用了一句話完成了,并且都是自注釋的,寫得讓人感覺十分流暢。
雖然這個實現運行效率不高,還有一些可以優化的地方,但我卻非常喜歡這種簡潔、高效(開發效率)的代碼,看著十分舒服。這也是C#的一個十分讓我入迷的地方->優雅:可以將心中的想法快速用代碼表現出來,高屋建瓴,一氣呵成,不必于在拘泥于細節。很多時候,在細節實現苦苦琢磨的時往往會忘記最開始突發的靈感和編程的樂趣。
同時我想起了前幾天發的一個算法練習的帖子,雖然用C#可以在20行之內實現,但一大片經驗豐富的程序員在4個小時之內用C語言(不能使用任何庫)卻無法完成。我想,對那同一個題目,用20行和用200行實現的時候的人心情是截然不同的吧。
原文鏈接:https://www.cnblogs.com/TianFang/archive/2009/08/16/1547050.html
相關推薦
- 2022-06-08 nacos項目啟動報錯:Connection refused: no further informa
- 2024-01-29 在DOS或Windows環境中,使用工具Debug
- 2023-02-09 C++存儲持續性生命周期原理解析_C 語言
- 2022-05-29 C#實現文字轉語音功能_C#教程
- 2022-12-08 C#?如何調用C++?dll?string類型返回_C#教程
- 2022-04-10 SpringBoot 導入插件報錯 Cannot resolve plugin org.spring
- 2023-02-18 python常用操作之使用多個界定符(分隔符)分割字符串的方法實例_python
- 2022-05-11 linq中的分組操作符_實用技巧
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支