国产探花免费观看_亚洲丰满少妇自慰呻吟_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語言程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 临夏县| 静宁县| 平阴县| 永兴县| 高唐县| 彩票| 绩溪县| 青浦区| 武平县| 永城市| 建宁县| 文成县| 富阳市| 航空| 南部县| 合山市| 凤台县| 东乡族自治县| 滁州市| 吴旗县| 岳西县| 朔州市| 武定县| 合肥市| 保山市| 法库县| 将乐县| 乌兰浩特市| 西和县| 黄龙县| 保康县| 凤凰县| 登封市| 永昌县| 阳山县| 沈丘县| 绿春县| 佛坪县| 万山特区| 清徐县| 静乐县|