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

Golang排列組合算法問題之全排列實(shí)現(xiàn)方法

 更新時(shí)間:2017年01月30日 14:28:02   作者:books1958  
這篇文章主要介紹了Golang排列組合算法問題之全排列實(shí)現(xiàn)方法,涉及Go語(yǔ)言針對(duì)字符串的遍歷及排列組合相關(guān)操作技巧,需要的朋友可以參考下

本文實(shí)例講述了Golang排列組合算法問題之全排列實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:

【排列組合問題】

一共N輛火車(0<N<10),每輛火車以數(shù)字1-9編號(hào),要求以字典序排序輸出火車出站的序列號(hào)。

輸入:

包括N個(gè)正整數(shù)(0<N<10),范圍為1到9,數(shù)字之間用空格分割,字符串首位不包含空格。

輸出:

輸出以字典序排序的火車出站序列號(hào),每個(gè)編號(hào)以空格隔開,每個(gè)輸出序列換行。

樣例輸入:

1 2 3

樣例輸出:

1 2 3
1 3 2
2 1 3
2 3 1
3 1 2
3 2 1

代碼實(shí)現(xiàn):

復(fù)制代碼 代碼如下:
package huawei
import (
    "fmt"
    "sort"
    "strings"
)
func Test7Base() {
    in := "5 2 3"
    result := outOrder(strings.Fields(in))
    dictSort(result)
    s := format(result)
    fmt.Println(s)
}
//輸入trainsNums,返回全部排列
//如輸入[1 2 3],則返回[123 132 213 231 312 321]
func outOrder(trainsNums []string) []string {
    COUNT := len(trainsNums)
    //檢查
    if COUNT == 0 || COUNT > 10 {
        panic("Illegal argument. trainsNums size must between 1 and 9.")
    }
    //如果只有一個(gè)數(shù),則直接返回
    if COUNT == 1 {
        return []string{trainsNums[0]}
    }
    //否則,將最后一個(gè)數(shù)插入到前面的排列數(shù)中的所有位置(遞歸)
    return insert(outOrder(trainsNums[:COUNT-1]), trainsNums[COUNT-1])
}
func insert(res []string, insertNum string) []string {
    //保存結(jié)果的slice
    result := make([]string, len(res)*(len(res[0])+1))
    index := 0
    for _, v := range res {
        for i := 0; i < len(v); i++ {
            //在v的每一個(gè)元素前面插入
            result[index] = v[:i] + insertNum + v[i:]
            index++
        }
        //在v最后面插入
        result[index] = v + insertNum
        index++
    }
    return result
}
//按字典順序排序
func dictSort(res []string) {
    sort.Strings(res)
}
//按指定格式輸出
func format(res []string) string {
    strs := make([]string, len(res))
    for i := 0; i < len(res); i++ {
        strs[i] = addWhiteSpace(res[i])
    }
    return strings.Join(strs, "\n")
}
//添加空格
func addWhiteSpace(s string) string {
    var retVal string
    for i := 0; i < len(s); i++ {
        retVal += string(s[i])
        if i != len(s)-1 {
            retVal += " "
        }
    }
    return retVal
}

希望本文所述對(duì)大家Go語(yǔ)言程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • goroutine?泄漏和避免泄漏實(shí)戰(zhàn)示例

    goroutine?泄漏和避免泄漏實(shí)戰(zhàn)示例

    這篇文章主要為大家介紹了goroutine?泄漏和避免泄漏實(shí)戰(zhàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • Go語(yǔ)言中結(jié)構(gòu)體的高級(jí)技巧分享

    Go語(yǔ)言中結(jié)構(gòu)體的高級(jí)技巧分享

    這篇文章主要為大家分享一下Go語(yǔ)言中結(jié)構(gòu)體的高級(jí)技巧,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以跟隨小編一起了解一下
    2023-08-08
  • golang日志框架之logrus的使用

    golang日志框架之logrus的使用

    這篇文章主要介紹了golang日志框架之logrus的使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • golang逗號(hào)ok模式整合demo

    golang逗號(hào)ok模式整合demo

    這篇文章主要為大家介紹了golang逗號(hào)ok模式整合demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11
  • Go泛型之泛型約束示例詳解

    Go泛型之泛型約束示例詳解

    這篇文章主要給大家介紹了關(guān)于Go泛型之泛型約束的相關(guān)資料,泛型是靜態(tài)語(yǔ)言中的一種編程方式,這種編程方式可以讓算法不再依賴于某個(gè)具體的數(shù)據(jù)類型,而是通過將數(shù)據(jù)類型進(jìn)行參數(shù)化,以達(dá)到算法可復(fù)用的目的,需要的朋友可以參考下
    2023-12-12
  • Go語(yǔ)言zip文件的讀寫操作

    Go語(yǔ)言zip文件的讀寫操作

    本文主要介紹了Go語(yǔ)言zip文件的讀寫操作,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • 淺談Go語(yǔ)言中的接口類型

    淺談Go語(yǔ)言中的接口類型

    Go語(yǔ)言中接口是一種抽象的類型,本文主要介紹了淺談Go語(yǔ)言中的接口類型,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-08-08
  • 完美解決golang go get私有倉(cāng)庫(kù)的問題

    完美解決golang go get私有倉(cāng)庫(kù)的問題

    這篇文章主要介紹了完美解決golang go get私有倉(cāng)庫(kù)的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-05-05
  • 深入分析Golang Server源碼實(shí)現(xiàn)過程

    深入分析Golang Server源碼實(shí)現(xiàn)過程

    這篇文章深入介紹了Golang Server源碼實(shí)現(xiàn)過程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-02-02
  • Go?channel實(shí)現(xiàn)批量讀取數(shù)據(jù)

    Go?channel實(shí)現(xiàn)批量讀取數(shù)據(jù)

    Go中的?channel?其實(shí)并沒有提供批量讀取數(shù)據(jù)的方法,需要我們自己實(shí)現(xiàn)一個(gè),使用本文就來為大家大家介紹一下如何通過Go?channel實(shí)現(xiàn)批量讀取數(shù)據(jù)吧
    2023-12-12

最新評(píng)論