算法基础:最大递减数问题(Golang实现)
2024-09-14 20:22:16
给出一个非负整数,找到这个非负整数中包括的最大递减数。一个数字的递减数是指相邻的数位从大到小排列的数字。
如: 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
}
最新文章
- UVA10325 The Lottery(容斥原理)
- scikit-learn算法选择图
- spring-poi-excle往单元格写入图片
- 【转】Caffe初试(四)数据层及参数
- MAC OS terminal 快捷键记录
- 【SQL】分配函数一枚[AllotToTable]
- 【原/转】ios指令集以及基于指令集的app包压缩策略
- 对石家庄铁道大学网站首页进行UI分析
- ionic 手机端如何嵌入视频iframe
- Codeforces Round #260 (Div. 1) --B. A Lot of Games (Trie)
- fs读取某个json文件的数据
- C#中继承,集合(Eleventh day)
- Devexpress XtraReports 交叉报表
- C++字符串按照指定规则切割的功能模板类,常用的一段检测记录运行时间的代码
- 细说REST API安全之防止重放攻击
- Javascript模式小记(一)
- iOS开发笔记-一种任意字体、颜色混排UILabel的实现
- Linux学习笔记之一————什么是Linux及其应用领域
- 【转载】Sqlserver的SQL语句实现分页查询
- opencv学习网站[国外网站]+ 各种学习资料