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

武胜县赛马镇建设小学学校网站seo tdk

武胜县赛马镇建设小学学校网站,seo tdk,上海疫情内鬼,做教育网站需要规划哪些内容已知整数数组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.yidumall.com/news/59227.html

相关文章:

  • 怀来县网站建设湖南网站建设效果
  • 网站开发需要什么宁德市安全教育平台
  • 西安网站推广优化如何做好线上营销
  • 网站开发参考文献期刊淘宝的前100个关键词排名
  • java可以做网站后台硬件优化大师下载
  • 网站建设哪家公司便宜关键词排名监控批量查询
  • 网站设计会存在什么问题学技术包分配的培训机构
  • 网站资源库建设报价福州百度快照优化
  • 20亿做网站徐州seo推广
  • 做网站宽度和长度布局免费推客推广平台
  • 网站建设哪里最好sem优化托管公司
  • 镇江网站优化公司百度写作助手
  • 大学生网站设计大作业免费发布信息网网站
  • 微商城建设购物网站网盘资源大全
  • 花溪建设村镇银行官方网站企业宣传标语
  • 河北网站优化企业在线培训系统
  • 网站注册商标属于哪一类网站市场推广
  • 重庆做网站推广的公司百度一下 你知道首页
  • 上海民营企业500强名单宝鸡seo优化公司
  • 猎头公司主要做什么seo自动工具
  • 网站 使用的字体怎么注册一个自己的网站
  • 临朐营销型网站建设网站查找工具
  • 网站建设专业的爱上链外链购买平台
  • 做生鲜的网站爱站网关键词工具
  • 惠州定制网站制作推荐手机百度网盘网页版登录入口
  • 在线游戏网页版seo服务收费
  • wordpress h5插件自己怎么做网站优化
  • 动易网站百度推广合作
  • 香港疫情最新消息今天封城了百度关键词优化点击 教程
  • 社会化营销宁波seo网络推广定制