当前位置: 首页 > news >正文

政协网站法治建设免费做彩页网站

政协网站法治建设,免费做彩页网站,网站建设与推广实训小结,php网站模板源码给你一个字符串数组 nums 和一个整数 k 。nums 中的每个字符串都表示一个不含前导零的整数。 返回 nums 中表示第 k 大整数的字符串。 注意:重复的数字在统计时会视为不同元素考虑。例如,如果 nums 是 ["1","2","2"]&am…

给你一个字符串数组 nums 和一个整数 k 。nums 中的每个字符串都表示一个不含前导零的整数。

返回 nums 中表示第 k 大整数的字符串。

注意:重复的数字在统计时会视为不同元素考虑。例如,如果 nums 是 ["1","2","2"],那么 "2" 是最大的整数,"2" 是第二大的整数,"1" 是第三大的整数。

示例 1:

输入:nums = ["3","6","7","10"], k = 4
输出:"3"
解释:
nums 中的数字按非递减顺序排列为 ["3","6","7","10"]
其中第 4 大整数是 "3"

示例 2:

输入:nums = ["2","21","12","1"], k = 3
输出:"2"
解释:
nums 中的数字按非递减顺序排列为 ["1","2","12","21"]
其中第 3 大整数是 "2"

示例 3:

输入:nums = ["0","0"], k = 2
输出:"0"
解释:
nums 中的数字按非递减顺序排列为 ["0","0"]
其中第 2 大整数是 "0"

提示:

  • 1 <= k <= nums.length <= 104
  • 1 <= nums[i].length <= 100
  • nums[i] 仅由数字组成
  • nums[i] 不含任何前导零

题解:当看到这个题目的时候,第一反应是将字符串转为整数,然后按照整数的大小进行排序,然后返回第K大的数字转为字符串结果就行了。 这个复杂度应该是O(nlgn)+O(M),其中n表示nums的长度,M表示所有字符串连起来的总长度。

于是,开始写代码。第一次提交:

class Solution {fun kthLargestNumber(nums: Array<String>, k: Int): String {val temp:Array<Int> = Array(nums.size){0}for(i in 0 until nums.size){temp[i]=nums[i].toInt()}temp.sort()return temp[nums.size-k].toString()}
}

很开心,没想到中等难度的题目这么简单。然后,执行出错!!Line 5: Exception in thread "main" java.lang.NumberFormatException: For input string: "6888794705"

哦哦,原来是超越整数的界限了。那么再来,我这次用Double数据类型。

class Solution {fun kthLargestNumber(nums: Array<String>, k: Int): String {/*val temp:Array<Int> = Array(nums.size){0}for(i in 0 until nums.size){temp[i]=nums[i].toInt()}*///nums.sort(){c->c.toInt()}//return nums[nums.size-k].toString()val sortedArr = nums.sortedWith(Comparator { s1, s2 ->val i1 = s1.toDouble()val i2 = s2.toDouble()(i1 - i2).toInt()        // Comparator 这个比较器默认返回的是Int类型,所以这里强制转换})return sortedArr[nums.size-k].toString()}
}

当输入倒数第二个测试用例的时候,也是一个数字有这么长的时候9999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999

又报错了!!

又超过限制了,于是又想到了一个办法,使用BigInteger类:

class Solution {fun kthLargestNumber(nums: Array<String>, k: Int): String {/*val temp:Array<Int> = Array(nums.size){0}for(i in 0 until nums.size){temp[i]=nums[i].toInt()}*///nums.sort(){c->c.toInt()}//return nums[nums.size-k].toString()val sortedArr = nums.sortedWith(Comparator { s1, s2 ->val i1 = s1.toBigInteger()val i2 = s2.toBigInteger()(i1 - i2).toInt()})return sortedArr[nums.size-k].toString()}
}

以为解决的是,但是toInt这个地方又越界了。。郁闷了一会之后,继续又想到了when这个单词:

class Solution {fun kthLargestNumber(nums: Array<String>, k: Int): String {/*val temp:Array<Int> = Array(nums.size){0}for(i in 0 until nums.size){temp[i]=nums[i].toInt()}*///nums.sort(){c->c.toInt()}//return nums[nums.size-k].toString()val sortedArr = nums.sortedWith(Comparator { s1, s2 ->val i1 = s1.toBigInteger()val i2 = s2.toBigInteger()when{i1<i2 -> -1 i1>i2 -> 1 else -> 0 }})return sortedArr[nums.size-k].toString()}
}

既然comparator要返回Int型,那么比较的话,只有三种情况,都返回就行了。终于通过了!

时间1328 ms

击败

N/A

内存69.8 MB

击败

N/A

http://www.yayakq.cn/news/75254/

相关文章:

  • 对网站建设公司说做网站用虚拟主机好不好
  • 建设网站要注意什么怎么做报名网站
  • 网站 空间 下载wordpress博客 分类
  • 系统网站怎么做判断 摘要wordpress
  • 温州网站建设方案服务中大型企业网络组网案例
  • 黑群晖wordpress建站软文技巧
  • 黄金网站软件入口免费假怀孕单子在线制作图片
  • 北京市建设工程第四检测所网站网页pc端
  • 东营组建网站wordpress get locale
  • 潍坊在线网站建设辅助网站怎么做的
  • 自己建网站数据怎么做天津塘沽爆炸案处理结果
  • 交互设计就业前景关键字优化技巧
  • 江苏省住房与城乡建设部网站做网站给源码吗
  • python做的网站有哪些网站高端设计公司哪家好
  • 企业网站建设情况说明建设网站的基本流程
  • 金凤区建设交通局网站北京网站制作设计
  • 自建网站营销是什么做平面计设和网站哪个好
  • 设计师网站都有哪些重大新闻事件
  • 织梦唯美网站源码零食软文范例300字
  • 莱阳有网站建设推广的吗注册企业有哪些基本流程
  • 吉隆网站建设浙江建设厅网站
  • 网站建设需注意点吾爱主题wordpress
  • 免费换友情链接天津seo
  • 为什么要做手机网站开发三亚网站怎么制作
  • asp网站好还是php网站好给别人做网站打电话推销
  • 搭建网站账户系统网站开发及代运营
  • 系统网站哪个好个人网站做导购要什么经营许可
  • 太仓网站建设有限公司教育网站制作论文
  • 西地那非片云南网站seo外包
  • 郑州做网站擎天凡科做网站是否安全