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

磐安住房和城乡建设部网站现在的网站做多大尺寸的

磐安住房和城乡建设部网站,现在的网站做多大尺寸的,广西智能网站建设报价,wordpress检验上传的文档154. 寻找旋转排序数组中的最小值 II - 力扣#xff08;LeetCode#xff09; 已知一个长度为 n 的数组#xff0c;预先按照升序排列#xff0c;经由 1 到 n 次 旋转 后#xff0c;得到输入数组。例如#xff0c;原数组 nums [0,1,4,4,5,6,7] 在变化后可能得到#xff1…154. 寻找旋转排序数组中的最小值 II - 力扣LeetCode 已知一个长度为 n 的数组预先按照升序排列经由 1 到 n 次 旋转 后得到输入数组。例如原数组 nums [0,1,4,4,5,6,7] 在变化后可能得到 若旋转 4 次则可以得到 [4,5,6,7,0,1,4]若旋转 7 次则可以得到 [0,1,4,4,5,6,7] 注意数组 [a[0], a[1], a[2], ..., a[n-1]] 旋转一次 的结果为数组 [a[n-1], a[0], a[1], a[2], ..., a[n-2]] 。 给你一个可能存在 重复 元素值的数组 nums 它原来是一个升序排列的数组并按上述情形进行了多次旋转。请你找出并返回数组中的 最小元素 。 你必须尽可能减少整个过程的操作步骤。 示例 1 输入nums [1,3,5] 输出1示例 2 输入nums [2,2,2,0,1] 输出0提示 n nums.length1 n 5000-5000 nums[i] 5000nums 原来是一个升序排序的数组并进行了 1 至 n 次旋转 class Solution {public int findMin(int[] nums) {//暴力解题// int len nums.length;// int ans nums[0];// for(int i 1 ;i len ; i) {// if(nums[i] ans) {// ans nums[i];// }// }// return ans;int left 0;int right nums.length - 1;while(left right) {int mid (leftright) / 2;if(nums[mid] nums[right]) right mid;else if(nums[mid] nums[right]) left mid1;else right--;}return nums[left];} } 每日一题今天是困难题。这道题目考察的二分很有意思。 读完题目发现这道题就是让我们去寻找最小值。那最暴力的方法也就是On的方法直接循环一次数组就可以得到最小值了。 二分的方法怎么做呢题目这里是会旋转数组的也就是说不知道数组会怎么样被选择但不论怎么旋转其实都可以知道有一个断点当然前后必须是连起来的也就是0下标的前面对应的是nums.length-1下标的数。这里用leftright来记录左右边界。由于一开始是升序的数组那么一定可以知道right下标对应的数是断点之后最大的数。我们分情况来看。 1.有旋转且旋转没有刚好复原 这种情况下断点一定在数组中间至少不会在边界0和 len-1的地方那么这时候lerft所指向的数一定是大于等于right的因为原数组是递增的。这时候的中点由于在中间有3种情况 1如果nums[mid]nums[right]说明mid所在的位置一定在断点之前。因为nums[left]都大于等于nums[right]了nums[mid]又大于nums[right]所以这时候说明mid左边都还是递增的。由于大于nums[right]说明mid的左边不可能有比right小的所以left mid1。 2如果nums[mid]nums[right]说明mid所在的位置由于小于nums[right]一定在断点之后。因为nums[right]是断点之后最大的而nums[left]又大于等于right所以说明此时mid的右边是都是递增的还没有到达断点。right mid。 3如果nums[mid] nums[right]有可能自mid之后都是nums[right]的值也就是一条直线这时候要往后退一个位置。因为即使退一个位置right的值也不会变而mid的值却可以往后退1位就可以再进行判断。如果这时候直接让rightmid有可能错过断点的位置。 2.顺序 顺序的话其实right就是最大的会一直往左边退直到退到0的位置。 3.逆序 逆序实际上right是最小的会一直往右边进直到right的位置。 这道题目对二分的理解很有帮助。
http://www.hkea.cn/news/14568929/

相关文章:

  • 云建站微网站网站首页布局分析
  • 网站开发与网站运营室内设计培训网课
  • 网站评论管理怎么做的wordpress+游戏网站
  • 网站被盗用好看又免费的图片素材网站
  • 手机端移动网站建设如何做一个论坛网站
  • 网站访客qq抓取原理张家港个人网站制作
  • 一流的镇江网站优化wordpress定制后台图片上传功能
  • 网站建设空间步骤详解网站建设类的计入什么科目
  • 专做定制旅游网站有哪些网站建设 cn
  • 网站开发有什么语言h5建站免费
  • 官方网站建设进度表商贸有限公司门头照片
  • 培训网站排名thinkphp做网站快吗
  • 多语言版本网站制作做网站用什么ide
  • 浙江建设招生网站学校的网站建设费如何入账
  • 义乌专业做网站的广州网站推广联盟
  • 国内简洁网站设计怎么棋牌网站建设
  • 检查网站是否做网站地图网络游戏推广
  • 免费域名注册服务网站网站建设---部署与发布
  • 房地产平面设计网站天津网站建设信息
  • 帝国cms手机网站制作企业网站建设犇类建筑
  • 用新域名做网站排名快吗网站建设捌金手指下拉十六
  • iis5.1新建网站加盟编程教育哪家好
  • 广州做网站制作公司开发网站需要什么人员
  • 郑州优化网站公司有哪些小的电商网站
  • 网站建设中gifwordpress能用的插件
  • 河间网站建设公司哪些网站做免费送东西的广告6
  • 网站建设收费标准新闻企业网站php源码免费下载
  • 福州网站设计软件公司办宽带需要多少钱
  • 北京 网站备案月付购物网站建站
  • 有经验的永州网站建设wordpress 加速版