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

网站建设公司价位删除wordpress主题底部

网站建设公司价位,删除wordpress主题底部,中国人才网,太原搜索排名提升已知整数数组nums,先按升序排序后,再旋转。旋转k位后,元素分别为nums[k],nums[k1]...nums[0]...nums[k-1]。请查找target 是否存在,如果存在返回所在索引;否则返回-1。假定nums没有重复的元素。 假定排序后的数组为{1…

已知整数数组nums,先按升序排序后,再旋转。旋转k位后,元素分别为nums[k],nums[k+1]...nums[0]...nums[k-1]。请查找target 是否存在,如果存在返回所在索引;否则返回-1。假定nums没有重复的元素。

假定排序后的数组为{1,2,3,4,5}。

旋转0位:不变。

旋转1位:{2,3,4,5,1}

旋转2位:{3,4,5,1,2}

旋转3位:{4,5,1,2,3}

旋转4位:{5,1,2,3,4}

解题思路

观察后,可以得到如下结论:

旋转数组,可以拆分成左右两个升序数组,且左数组的任意元素都大于右数组的任意元素。

分两步:

  • 找到数组的分界线RBegin,[0,RBegin)是左数组,[RBegin,n)是右数组。特殊情况:只有一个升序数组,则RBegin为0,左数组为空。
  • 如果是小于等于nums.back(),在右边找;否则在左边找。升序寻找元素之前已经讲过了,就不累赘了。
            1. 寻找RBegin

nums[mid] < nums.back()

扔掉右边,不扔mid

nums[mid] == nums.back()

扔掉右边,不扔mid

nums[mid] > nums.back()

扔掉左边,扔掉mid

故用左开右闭空间。

代码

class Solution {
public:
    int search(vector<int>& nums, int target) {
        int rBegin = FindRBegin(nums);
        if (target <= nums.back())
        {
            return Find(nums, rBegin, nums.size(), target);
        }
        return Find(nums, 0, rBegin, target);
    }
    int FindRBegin(const vector<int>& nums)
    {
        int left = -1, r = nums.size()-1;//左开右闭
        while (r - left > 1)
        {
            const int mid = left + (r - left) / 2;
            if (nums[mid] <= nums.back())
            {
                r = mid;
            }
            else
            {
                left = mid;
            }
        }
        return r;
    }
    int Find(const vector<int>& nums, int left, int r, int target)
    {
        while (r - left > 1)
        {
            const auto mid = left + (r - left) / 2;
            if (nums[mid] <= target)
            {
                left = mid;
            }
            else
            {
                r = mid;
            }
        }
        return (target == nums[left]) ? left : -1;
    }
};
int main()
{
    vector<int> vNums = {1,2,3,4,6};
    auto res = Solution().search(vNums, 4);
    std::cout << "index:" <<  res;
    if (-1 != res)
    {
        std::cout << " value:" << vNums[res];
    }
}

注意

开发及测试操作系统:Windows10(安装的时候没注意,安装成了英文版)
开发及测试环境:Microsoft Visual Studio 2022  
如果还不明白,请看我的视频;如果看完视频,还是不明白,请下载源码后,直接修改。
 

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

相关文章:

  • 如何做产品网站建设个人网站的投稿平台
  • 建设网站要注册公司吗温州网页网站制作
  • 十大猎头公司排名seo在线优化系统
  • 网站建设网页怎么排列顺序网站建设公司-山而
  • 网站开发网站源码美区能和国区家庭共享吗
  • 10分钟免费建网站帮别人做网站开票开什么税目
  • 51购物网官方网站贵 建设厅网站文件
  • 个体户营业执照可以网站备案杭州手机建站模板
  • 自己找网站开发项目免费论坛创建
  • 西安网站seo价格佛山哪里做网站
  • 网站建设的前端和后端做三轨网站犯法吗
  • 网站不能粘贴怎么做网站建设计划书 模板下载
  • 苏州网联盛网站建设成立一个公司需要哪些流程
  • 西安网站建设培训学校广东小程序系统开发
  • 营销型网站建设的优势有哪些怎么修改wordpress站点代码
  • 网站推广网站关键词排名怎么做上海网站优化推广公司
  • 哪里有免费的域名注册建网站php7 wordpress
  • 优化算法 网站合肥晚报社官方网站
  • 怎样找到正规代加工网站网站开发语言入门
  • 购买域名网站佛山禅城网站建设
  • 哈尔滨公司网站开发北京做网站优化的科技公司
  • 做创新方法工作的网站网站代码优化目的
  • 常熟苏州网站建设公司网站进不去qq空间
  • 微网站开发流程阿里云域名注册备案流程
  • 网站广告代码seo如何提升排名收录
  • 建设中医知识学习网站jpress与wordpress
  • 网站建设教程 金旭亮代做网站的好处
  • 企业网站建设公司 丰台邯郸做网站优化
  • 宜宾网站开发网站建设 租赁
  • 成都网站定制费用如何登陆公司网站后台