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

宁波高端网站建设推广假冒建设厅网站

宁波高端网站建设推广,假冒建设厅网站,ui培训心得体会总结,WordPress建站要花钱目录 题目:寻找峰值_牛客题霸_牛客网 (nowcoder.com) 题目的接口: 解题思路: 代码: 过啦!!! 题目:数组中的逆序对_牛客题霸_牛客网 (nowcoder.com) 题目的接口: …

目录

题目:寻找峰值_牛客题霸_牛客网 (nowcoder.com)

题目的接口:

解题思路:

代码:

过啦!!!

题目:数组中的逆序对_牛客题霸_牛客网 (nowcoder.com)

题目的接口:

解题思路:

代码:

过啦!!!

写在最后:


题目:寻找峰值_牛客题霸_牛客网 (nowcoder.com)

题目的接口:

package main/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param nums int整型一维数组 * @return int整型
*/
func findPeakElement( nums []int ) int {// write code here
}

解题思路:

首先补充一句:这道题的自测有问题不要信,逻辑正确就直接提交就好。

这道题也是一道很经典的二分题目,二分并不是一定要有序的数组才能使用二分,二分的精髓在于数据的单调性,二分就是通过数据的单调性,以及寻找一个参照物来快速排除一部分的数据,

就拿这道题来说,题目要求是无论返回哪个山峰都行,那我们只有两种情况需要考虑,一个是在山峰的左边(递增区间)一个是在山峰的右边(递减区间),如果是在递增区间,我们就可以把左边的数据排除,如果是在递减区间,我们就能将右边连同自己这段数据排除,这样就使用到了二分的思想,代码如下

代码:

package main/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param nums int整型一维数组 * @return int整型
*/
func findPeakElement( nums []int ) int {left, right := 0, len(nums)-1for left < right {mid := left + (right - left + 1) / 2if nums[mid] > nums[mid-1] {left = mid} else {right = mid-1}}return left
}

过啦!!!

题目:数组中的逆序对_牛客题霸_牛客网 (nowcoder.com)

题目的接口:

package main/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param nums int整型一维数组 * @return int整型
*/
func InversePairs( nums []int ) int {// write code here
}

解题思路:

这道题目的如果使用暴力求解那肯定就是 O(N) 基本的时间复杂度,想要做到 N*logN 就得想其他的解决方案,这道题也算是一道非常经典的题目,考察的是归并排序的写法

我们通过使用归并排序的思想就可以在使用归并排序的过程中完成题目的要求,代码如下

代码:

package main/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param nums int整型一维数组* @return int整型*/
func InversePairs(nums []int) int {if len(nums) < 2 {return 0}count := 0var mergeSort func(left, right int)var merge func(left, right, mid int)mergeSort = func(left, right int) {if left >= right {return}mid := left + (right-left)/2mergeSort(left, mid)mergeSort(mid+1, right)merge(left, right, mid)}merge = func(left, right, mid int) {l, r := left, mid+1res := make([]int, right-left+1)index := 0for l <= mid && r <= right {if nums[l] <= nums[r] {res[index] = nums[l]l++index++} else {res[index] = nums[r]r++index++count += mid + 1 - lcount %= 1000000007}}for l <= mid {res[index] = nums[l]index++l++}for r <= right {res[index] = nums[r]index++r++} l = leftfor _, v := range res {nums[l] = vl++}}mergeSort(0, len(nums)-1)return count
}

过啦!!!

写在最后:

以上就是本篇文章的内容了,感谢你的阅读。

如果感到有所收获的话可以给博主点一个哦。

如果文章内容有遗漏或者错误的地方欢迎私信博主或者在评论区指出~


文章转载自:

http://bgyZqunH.yrfxb.cn
http://YPdEOHFp.yrfxb.cn
http://Y6e585Vp.yrfxb.cn
http://xttJeTfT.yrfxb.cn
http://jwrb08Xc.yrfxb.cn
http://1pCen8kF.yrfxb.cn
http://bgCy0egz.yrfxb.cn
http://E7CBuYAk.yrfxb.cn
http://zxcabQGX.yrfxb.cn
http://yivEY6eC.yrfxb.cn
http://0w1dJ5fx.yrfxb.cn
http://xL15wWE3.yrfxb.cn
http://0Tf7AVp3.yrfxb.cn
http://jQaSAbCe.yrfxb.cn
http://vkr7I4Tc.yrfxb.cn
http://nBaYblRY.yrfxb.cn
http://zP7dOyto.yrfxb.cn
http://IzF8DugJ.yrfxb.cn
http://FT92XWGz.yrfxb.cn
http://n33V03eE.yrfxb.cn
http://qN6POe8w.yrfxb.cn
http://emevX6tM.yrfxb.cn
http://wuvlTjzJ.yrfxb.cn
http://dHbfGOTu.yrfxb.cn
http://i9fjRst4.yrfxb.cn
http://JeGEtLki.yrfxb.cn
http://hFBMrLXu.yrfxb.cn
http://uxJ0SfxW.yrfxb.cn
http://hSrNGx58.yrfxb.cn
http://kwyVW8OB.yrfxb.cn
http://www.dtcms.com/wzjs/651687.html

相关文章:

  • 公司开发个网站有哪些安卓开发培训
  • 给我一个免费网站吗漫画WordPress
  • 专业做网站制作的公司做软件常用的网站有哪些
  • 一个完整的企业网站怎么做制作图网老版
  • 移动网站开发的视频下载做网站找谷谷网络比较好
  • 网站建设首页该放什么arttemplate做电商网站
  • 做外贸商城网站个人网站注册费用
  • 深圳网站建设ejaket更改wordpress链接数据库
  • 营销型企业网站核心大前端网站
  • 网站开发技术是什么专业会的wordpress页面怎么编辑
  • 做网站怎么发布wordpress123页
  • 网站使用的主色调专业建站
  • 广州有做虚拟货币网站品牌创建策划方案
  • 东莞网站建设公司服务平台全国建设通官网
  • 有口碑的网站建设公司永久免费网站怎么创建
  • 网站获取客户信息需要备案吗wordpress仿百度贴吧
  • 企业网站psd模板分销商城开发公司
  • 网站开发美工总结php 视频播放网站开发
  • 佛山网站排名wordpress执行流程
  • 做互联网推广的公司搜索引擎优化的主要策略
  • 延吉 网站建设南京老牌网站建设公司
  • 公司网站怎么发布文章山东网站建设团队
  • 湛江网站优化青岛苍南网站建设
  • 做网站怎么赚钱吗营销型网站设计方针
  • 做兼职设计去哪个网站迅捷流程图在线制作网站
  • 网站建设 创业wordpress博客主题自媒体
  • 网页网站的区别是什么建筑工程网价是什么意思
  • 静态网站更新单页加盟网站模板
  • 套模板网站价格wordpress html插件安装
  • 太原网站优化怎么做wordpress模板用法