首頁 後端開發 Golang 如何按映射值的降序對映射進行排序?

如何按映射值的降序對映射進行排序?

Dec 12, 2024 am 11:59 AM

How Do I Sort a Map by Its Values in Descending Order?

如何按值對映射進行排序

在處理目標是對鍵值進行排序的映射時會出現此問題基於按降序排列的值的對。例如,給定一個像這樣的地圖:

map[string]int{
    "hello": 10,
    "foo": 20,
    "bar": 20,
}

人們可能想如下列印排序對:

foo, 20
bar, 20
hello, 10

解決方案

解決方案
func rankByWordCount(wordFrequencies map[string]int) PairList {
    pl := make(PairList, len(wordFrequencies))
    i := 0
    for k, v := range wordFrequencies {
        pl[i] = Pair{k, v}
        i++
    }
    sort.Sort(sort.Reverse(pl))
    return pl
}

type Pair struct {
    Key   string
    Value int
}

type PairList []Pair

func (p PairList) Len() int           { return len(p) }
func (p PairList) Less(i, j int) bool { return p[i].Value < p[j].Value }
func (p PairList) Swap(i, j int)      { p[i], p[j] = p[j], p[i] }

此問題的解決方案是透過提供必要的len、less 和swap 函數來實作排序介面。以下是範例實作:要使用此函數,請將對應作為參數傳遞給rankByWordCount,這將傳回鍵值對的排序清單。然後,您可以迭代列表以列印排序結果。

以上是如何按映射值的降序對映射進行排序?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Stock Market GPT

Stock Market GPT

人工智慧支援投資研究,做出更明智的決策

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Golang中使用的空結構{}是什麼 Golang中使用的空結構{}是什麼 Sep 18, 2025 am 05:47 AM

struct{}是Go中無字段的結構體,佔用零字節,常用於無需數據傳遞的場景。它在通道中作信號使用,如goroutine同步;2.用作map的值類型模擬集合,實現高效內存的鍵存在性檢查;3.可定義無狀態的方法接收器,適用於依賴注入或組織函數。該類型廣泛用於表達控制流與清晰意圖。

您如何在Golang讀寫文件? 您如何在Golang讀寫文件? Sep 21, 2025 am 01:59 AM

Goprovidessimpleandefficientfilehandlingusingtheosandbufiopackages.Toreadasmallfileentirely,useos.ReadFile,whichloadsthecontentintomemorysafelyandautomaticallymanagesfileoperations.Forlargefilesorincrementalprocessing,bufio.Scannerallowsline-by-liner

Golang Web服務器上下文中的中間件是什麼? Golang Web服務器上下文中的中間件是什麼? Sep 16, 2025 am 02:16 AM

MiddlewareinGowebserversarefunctionsthatinterceptHTTPrequestsbeforetheyreachthehandler,enablingreusablecross-cuttingfunctionality;theyworkbywrappinghandlerstoaddpre-andpost-processinglogicsuchaslogging,authentication,CORS,orerrorrecovery,andcanbechai

解決 Go WebSocket EOF 錯誤:保持連接活躍 解決 Go WebSocket EOF 錯誤:保持連接活躍 Sep 16, 2025 pm 12:15 PM

本文旨在解決在使用 Go 語言進行 WebSocket 開發時遇到的 EOF (End-of-File) 錯誤。該錯誤通常發生在服務端接收到客戶端消息後,連接意外關閉,導致後續消息無法正常傳遞。本文將通過分析問題原因,提供代碼示例,並給出相應的解決方案,幫助開發者構建穩定可靠的 WebSocket 應用。

在 Go 程序中啟動外部編輯器並等待其完成 在 Go 程序中啟動外部編輯器並等待其完成 Sep 16, 2025 pm 12:21 PM

本文介紹瞭如何在 Go 程序中啟動外部編輯器(如 Vim 或 Nano),並等待用戶關閉編輯器後,程序繼續執行。通過設置 cmd.Stdin、cmd.Stdout 和 cmd.Stderr,使得編輯器能夠與終端進行交互,從而解決啟動失敗的問題。同時,展示了完整的代碼示例,並提供了注意事項,幫助開發者順利實現該功能。

您如何在Golang應用程序中處理優雅的關閉? 您如何在Golang應用程序中處理優雅的關閉? Sep 21, 2025 am 02:30 AM

GraceFulShutDownSingoApplicationsAryEssentialForReliability,獲得InteralceptigningsignAssignalSlikIntAndSigIntAndSigTermusingTheos/signalPackageToInitiateShutDownDownderders,然後st​​oppinghttpserverserversergrace,然後在shut'sshutdown()shutdown()shutdowndowndown()modecto toalawallactiverequestiverequestivereplaceversgraceversgraceversgraceversgrace

如何從Golang中的文件中讀取配置 如何從Golang中的文件中讀取配置 Sep 18, 2025 am 05:26 AM

使用標準庫的encoding/json包讀取JSON配置文件;2.使用gopkg.in/yaml.v3庫讀取YAML格式配置;3.結合os.Getenv或godotenv庫使用環境變量覆蓋文件配置;4.使用Viper庫支持多格式配置、環境變量、自動重載等高級功能;必須定義結構體保證類型安全,妥善處理文件和解析錯誤,正確使用結構體標籤映射字段,避免硬編碼路徑,生產環境推薦使用環境變量或安全配置存儲,可從簡單的JSON開始,需求復雜時遷移到Viper。

什麼是CGO,何時在Golang中使用它 什麼是CGO,何時在Golang中使用它 Sep 21, 2025 am 02:55 AM

CGOenablesGotocallCcode,allowingintegrationwithClibrarieslikeOpenSSL,accesstolow-levelsystemAPIs,andperformanceoptimization;itrequiresimporting"C"withCheadersincomments,usesC.function()syntax,anddemandscarefulmemorymanagement.However,CGOinc

See all articles