给出一个非负整数,找到这个非负整数中包括的最大递减数。一个数字的递减数是指相邻的数位从大到小排列的数字。

如: 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
}

最新文章

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

热门文章

  1. HttpOnly
  2. Global中的事件执行顺序
  3. TC Asia Competition
  4. C#中使用正则表达式提取超链接地址的集中方法(转)
  5. 转自 z55250825 的几篇关于FFT的博文(一)
  6. jquery插件colortip(tooltip类型)
  7. 使用Arcglobe 10与3dmax建立三维城市
  8. 【CSS】Intermediate1:Class and ID Selectors
  9. 【HTML】Beginner2:page title
  10. linux获取目录下文件