国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Golang > 正文

Golang最大遞減數算法問題分析

2020-04-01 19:07:16
字體:
來源:轉載
供稿:網友

本文實例講述了Golang最大遞減數算法問題。分享給大家供大家參考,具體如下:

給出一個非負整數,找到這個非負整數中包含的最大遞減數。一個數字的遞減數是指相鄰的數位從大到小排列的數字。

如: 95345323,遞減數有:953,95,53,53,532,32, 那么最大的遞減數為953。

如果輸入的數字為負數,返回-1。

如果找不到遞減數,也返回-1.

代碼實現:

復制代碼 代碼如下:
package huawei
import (
    "fmt"
    "sort"
    "strconv"
)
func Test5Base() {
    num := 431492
    degressiveNums := getDegressiveNums(num)
    max := -1
    if len(degressiveNums) > 0 {
        max = getMax(degressiveNums)
    }
    fmt.Println("max:", max)
}
//獲取num的所有遞減數
func getDegressiveNums(num int) []int {
    if num < 0 {
        return []int{-1}
    }
    degressiveNums := make([]int, 0)
    numStr := strconv.Itoa(num)
    length := len(numStr)
    //長度為i的子串
    for i := 2; i < length; i++ {
        //從j開始截取
        for j := 0; j < length-i+1; j++ {
            //截取數字
            n, err := strconv.Atoi(numStr[j : j+i])
            checkError(err, "string to integer")
            //是否為遞減數
            if isDegressive(n) {
                degressiveNums = append(degressiveNums, n)
            }
        }
    }
    return degressiveNums
}
//判斷數字num是否是遞減數
func isDegressive(num int) bool {
    weishu := make([]int, 0)
    for num >= 1 {
        n := num % 10
        weishu = append(weishu, n)
        num /= 10
    }
    return sort.IntsAreSorted(weishu)
}
//獲取一個slice中最大的數
func getMax(nums []int) int {
    if len(nums) == 0 {
        panic("empty slice.")
    }
    max := nums[0]
    for i := 1; i < len(nums); i++ {
        if nums[i] > max {
            max = nums[i]
        }
    }
    return max
}

 

希望本文所述對大家Go語言程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 鄱阳县| 新巴尔虎左旗| 景泰县| 嵊泗县| 彭州市| 南平市| 黑水县| 新昌县| 肥东县| 澎湖县| 双鸭山市| 平塘县| 桑植县| 儋州市| 西藏| 定襄县| 斗六市| 尖扎县| 南溪县| 营口市| 旬阳县| 金沙县| 固镇县| 银川市| 东安县| 商南县| 台湾省| 东兰县| 忻州市| 常熟市| 望奎县| 和政县| 乌鲁木齐县| 麟游县| 富宁县| 五河县| 上蔡县| 丰都县| 桐梓县| 望谟县| 安塞县|