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

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

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

服務器之家 - 腳本之家 - Golang - Golang算法問題之整數拆分實現方法分析

Golang算法問題之整數拆分實現方法分析

2020-05-05 13:52books1958 Golang

這篇文章主要介紹了Golang算法問題之整數拆分實現方法,結合實例形式分析了Go語言數值運算與數組遍歷相關操作技巧,需要的朋友可以參考下

本文實例講述了Golang算法問題之整數拆分實現方法。分享給大家供大家參考,具體如下:

一個整數總可以拆分為2的冪的和,例如:

7=1+2+4
7=1+2+2+2
7=1+1+1+4
7=1+1+1+2+2
7=1+1+1+1+1+2
7=1+1+1+1+1+1+1

總共有6種不同的拆分方式。

再比如:4可以拆分成:4 = 4,4 = 1 + 1 + 1 + 1,4 = 2 + 2,4=1+1+2。

用f(n)表示n的不同拆分的種數,例如f(7)=6.

要求編寫程序,讀入n(不超過1000000),輸出f(n)

輸入:一個整數N(1<=N<=1000000)。

輸出:f(n)

輸入數據如果超出范圍,輸出-1。

樣例輸入:

7

樣例輸出:

6

代碼實現:

復制代碼 代碼如下:
package huawei
import (
    "fmt"
)
func Test08Base() {
    input := 1000000
    output := numberSplit(input)
    fmt.Println(output)
}
func numberSplit(n int) int {
    if n < 1 || n > 1000000 {
        return -1
    }
    //1=1,1種拆分方式
    if n == 1 {
        return 1
    }
    //2=2,2=1+1,2種拆分方式
    if n == 2 {
        return 2
    }
    //n>=3
    //保存已經計算出來的數值
    data := make([]int, n+1)
    data[0] = 0 //該值無意義純占位作用
    data[1] = 1
    data[2] = 2
    for i := 3; i <= n; i++ {
        if i%2 == 0 {
            //偶數
            data[i] = data[i-2] + data[i/2]
        } else {
            //奇數
            data[i] = data[i-1]
        }
    }
    return data[n]
}

 

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

延伸 · 閱讀

精彩推薦
  • GolangGolang中Bit數組的實現方式

    Golang中Bit數組的實現方式

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

    天易獨尊11682021-06-09
  • Golanggolang的httpserver優雅重啟方法詳解

    golang的httpserver優雅重啟方法詳解

    這篇文章主要給大家介紹了關于golang的httpserver優雅重啟的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,...

    helight2992020-05-14
  • Golanggolang json.Marshal 特殊html字符被轉義的解決方法

    golang json.Marshal 特殊html字符被轉義的解決方法

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

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

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

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

    a165861639710342021-03-08
  • Golanggo語言制作端口掃描器

    go語言制作端口掃描器

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

    腳本之家3642020-04-25
  • Golanggolang如何使用struct的tag屬性的詳細介紹

    golang如何使用struct的tag屬性的詳細介紹

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

    Go語言中文網11352020-05-21
  • GolangGolang通脈之數據類型詳情

    Golang通脈之數據類型詳情

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

    4272021-11-24
  • Golanggo日志系統logrus顯示文件和行號的操作

    go日志系統logrus顯示文件和行號的操作

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

    SmallQinYan12302021-02-02
主站蜘蛛池模板: 黄网在线观看免费网站台湾swag | 亚洲精品免费视频 | 免费国产一级观看完整版 | 国产精品1区2区 | 2021麻豆剧果冻传媒入口永久 | 日本人成年视频在线观看 | 日韩欧美在线观看综合网另类 | 美女脱小内内给男生摸j | 成全动漫视频在线观看 | 手机看片1024日韩 | 青青热久麻豆精品视频在线观看 | 国产精品露脸国语对白河北 | 亚洲天堂.com| 欧美久久一区二区三区 | 日本成人黄色网址 | 九九精品久久 | 猫影视tv接口 | 肉浦团在线观看 | 4虎影院永久地址www | 秘书在办公室疯狂被hd | 日本xxoo动图网站欧美 | 99热影院| 99视频在线免费观看 | 女明星放荡高h日常生活 | free性videoxxⅹ印度| 亚洲国产婷婷俺也色综合 | 韩国理论三级在线观看视频 | 5x社区发源地最新地址 | 久热这里只有精品99国产6 | 精品国内自产拍在线视频 | 亚洲免费视频在线观看 | 日本不卡高清免费v日本 | 欧美肥b| 亚洲精品国产一区二区三区在 | 91国内精品久久久久怡红院 | 欧美一区二区三区在线观看免费 | 欧洲久久 | 草莓视频旧版 | 亚洲狠狠婷婷综合久久蜜桃 | 69av导航 | 羞羞视频免费观 |