一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術(shù)及教程分享平臺!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Golang - Golang排列組合算法問題之全排列實(shí)現(xiàn)方法

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

2020-05-05 13:28books1958 Golang

這篇文章主要介紹了Golang排列組合算法問題之全排列實(shí)現(xiàn)方法,涉及Go語言針對字符串的遍歷及排列組合相關(guān)操作技巧,需要的朋友可以參考下

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

【排列組合問題】

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

輸入:

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

輸出:

輸出以字典序排序的火車出站序列號,每個(gè)編號以空格隔開,每個(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
}

 

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

延伸 · 閱讀

精彩推薦
  • GolangGolang中Bit數(shù)組的實(shí)現(xiàn)方式

    Golang中Bit數(shù)組的實(shí)現(xiàn)方式

    這篇文章主要介紹了Golang中Bit數(shù)組的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    天易獨(dú)尊11682021-06-09
  • Golanggolang json.Marshal 特殊html字符被轉(zhuǎn)義的解決方法

    golang json.Marshal 特殊html字符被轉(zhuǎn)義的解決方法

    今天小編就為大家分享一篇golang json.Marshal 特殊html字符被轉(zhuǎn)義的解決方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧 ...

    李浩的life12792020-05-27
  • Golanggolang 通過ssh代理連接mysql的操作

    golang 通過ssh代理連接mysql的操作

    這篇文章主要介紹了golang 通過ssh代理連接mysql的操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    a165861639710342021-03-08
  • Golanggolang如何使用struct的tag屬性的詳細(xì)介紹

    golang如何使用struct的tag屬性的詳細(xì)介紹

    這篇文章主要介紹了golang如何使用struct的tag屬性的詳細(xì)介紹,從例子說起,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看...

    Go語言中文網(wǎng)11352020-05-21
  • GolangGolang通脈之?dāng)?shù)據(jù)類型詳情

    Golang通脈之?dāng)?shù)據(jù)類型詳情

    這篇文章主要介紹了Golang通脈之?dāng)?shù)據(jù)類型,在編程語言中標(biāo)識符就是定義的具有某種意義的詞,比如變量名、常量名、函數(shù)名等等,Go語言中標(biāo)識符允許由...

    4272021-11-24
  • Golanggolang的httpserver優(yōu)雅重啟方法詳解

    golang的httpserver優(yōu)雅重啟方法詳解

    這篇文章主要給大家介紹了關(guān)于golang的httpserver優(yōu)雅重啟的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,...

    helight2992020-05-14
  • Golanggo日志系統(tǒng)logrus顯示文件和行號的操作

    go日志系統(tǒng)logrus顯示文件和行號的操作

    這篇文章主要介紹了go日志系統(tǒng)logrus顯示文件和行號的操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    SmallQinYan12302021-02-02
  • Golanggo語言制作端口掃描器

    go語言制作端口掃描器

    本文給大家分享的是使用go語言編寫的TCP端口掃描器,可以選擇IP范圍,掃描的端口,以及多線程,有需要的小伙伴可以參考下。 ...

    腳本之家3642020-04-25
主站蜘蛛池模板: 校园纯肉H教室第一次 | 亚洲成人91 | 古装一级无遮挡毛片免费观看 | 波多野结衣一区 | 男人的天堂久久爱 | 男人插曲女人身体 | 国产欧美日韩精品高清二区综合区 | 亚洲午夜久久久久影院 | 国产一区二区三区四卡 | 亚洲免费精品 | 挺进白嫩老师下面视频 | 日本精品一区二区三区 | 午夜爽喷水无码成人18禁三级 | fistingvideos头交尿眼 | 日韩精品免费一级视频 | 男女男精品视频免费观看 | sao虎影院桃红视频在线观看 | 秋霞宅宅236理论片 秋霞一级黄色片 | 精品成人一区二区三区免费视频 | 日本一区二区三区精品 | 男人猛进女人屁股免费 | 大肥臀风间由美 中文字幕 大东北chinesexxxx露脸 | ssni-497新任美脚女教师 | 久久精品热只有精品 | 好男人免费高清在线观看2019 | 日韩永久在线观看免费视频 | tube8最近日本护士 | 毛片啪啪视频 | 日本一区二区三区久久精品 | 91视在线国内在线播放酒店 | 99久热只有精品视频免费看 | 暖暖影院日本版 | 免费一级特黄特色大片 | 免费观看小视频 | 免费毛片在线观看 | 国产麻豆剧果冻传媒影视4934 | 午夜香蕉成视频人网站高清版 | 第一次出血videos | 亚欧成人中文字幕一区 | 色欲都市 | 国产成人欧美 |