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

企业建设网站的案例图片搜索图片识别

企业建设网站的案例,图片搜索图片识别,网站建设网站公司哪家好,做网站设计的电脑需要什么配置目录 题目解法初始数组1. 分解阶段2. 合并阶段结果 为什么要创建长整型ll mid l ((r - l) >> 1);其中的>>是什么意思 题目 给你一个整数数组 nums,请你将该数组升序排列。 你必须在 不使用任何内置函数 的情况下解决问题,时间复杂度为 O…

目录

  • 题目
  • 解法
      • 初始数组
      • 1. 分解阶段
      • 2. 合并阶段
      • 结果
  • 为什么要创建长整型
  • ll mid = l + ((r - l) >> 1);其中的>>是什么意思

题目

给你一个整数数组 nums,请你将该数组升序排列。

你必须在 不使用任何内置函数 的情况下解决问题,时间复杂度为 O(nlog(n)),并且空间复杂度尽可能小。

解法

typedef long long ll;
const int N = 1e5 + 1;
class Solution {ll help[N];void merge(vector<int>& nums, ll l, ll r) {//1、将数组排序if (l >= r) return;ll mid = l + ((r - l) >> 1);ll i = l, j = mid + 1, t = l;while (i <= mid && j <= r) {help[t++] = nums[i] <= nums[j] ? nums[i++] : nums[j++];}//2、将左半区域剩余元素排序while (i <= mid) {help[t++] = nums[i++];}//3、将右半区域剩余元素排序while (j <= r) {help[t++] = nums[j++];}//4、复制数组for (int i = l; i <= r; i++) {nums[i] = help[i];}return;}void mergeSort(vector<int>& nums, ll l, ll r) {if (l < r) {ll mid = l + ((r - l) >> 1);//左边区域mergeSort(nums, l, mid);//右边区域mergeSort(nums, mid + 1, r);//合并左右区域merge(nums, l, r);}}public:vector<int> sortArray(vector<int>& nums) {int n = nums.size();mergeSort(nums, 0, n - 1);return nums;}
};

好的,下面我将详细展示使用归并排序的过程,以数组 nums = {38, 27, 43, 3, 9, 82, 10} 为例。

初始数组

nums = {38, 27, 43, 3, 9, 82, 10}

1. 分解阶段

归并排序首先将数组分解成子数组,直到每个子数组只包含一个元素。

  1. 初始分解:

    {38, 27, 43, 3, 9, 82, 10}
    
  2. 继续分解:

    {38, 27, 43}  {3, 9, 82, 10}
    
  3. 再次分解:

    {38} {27, 43}  {3, 9} {82, 10}
    
  4. 继续分解:

    {38} {27} {43}  {3} {9} {82} {10}
    

2. 合并阶段

接下来开始合并和排序:

  1. 合并 {27}{43}

    {27, 43}
    
  2. 合并 {27, 43}{38}

    {27, 38, 43}
    
  3. 合并 {3}{9}

    {3, 9}
    
  4. 合并 {82}{10}

    {10, 82}
    
  5. 合并 {3, 9}{10, 82}

    {3, 9, 10, 82}
    
  6. 最后合并 {27, 38, 43}{3, 9, 10, 82}

    {3, 9, 10, 27, 38, 43, 82}
    

结果

经过归并排序后,数组 nums 最终变为:

nums = {3, 9, 10, 27, 38, 43, 82}

为什么要创建长整型

typedef long long ll;:这行代码为 long long 类型创建了一个别名 ll。这样,在后续的代码中,你可以使用 ll 来代替 long long,使代码更简洁易读。

const int N = 1e5 + 1;:这行代码定义了一个常量 N,其值为 100001。通常在算法中,N 可能用于表示数组的最大大小或某种限制,以确保在使用时不会越界。

在 C++ 中,创建 long long 类型的原因主要是为了处理更大的整数范围。long long 通常用于存储可能超出 int 范围的数值,特别是在涉及到大数运算、数组索引、计数或求和时。以下是一些具体的原因:

  1. 数值范围int 的范围通常是 -2,147,483,648 到 2,147,483,647,而 long long 的范围可以达到 -9,223,372,036,854,775,808 到 9,223,372,036,854,775,807,适合处理更大的数值。

  2. 避免溢出:在进行大量累加、乘法等运算时,如果使用 int,可能会出现溢出错误。使用 long long 可以降低这种风险。

  3. 算法需要:在一些算法(如动态规划、图算法等)中,可能需要处理大量数据或计算结果,使用 long long 确保结果不会溢出。

因此,在需要处理较大整数的情况下,使用 long long 是一种常见的做法。

ll mid = l + ((r - l) >> 1);其中的>>是什么意思

“”>> 是位移运算符,表示右移操作。在这个表达式中,(r - l) >> 1 相当于将 (r - l) 的值除以 2,用于计算中间值 mid,以提高效率。

http://www.qdjiajiao.com/news/5072.html

相关文章:

  • 官方网站建设合同网络营销的基本特征有哪七个
  • 深圳市官网网站建设平台做网站用什么软件
  • 网站站长在哪登陆后台如何推广app
  • 遵义市网站建设seo优化技术培训中心
  • 旅游网站开发 结束语优化教程
  • 西安模板网站建设安徽网络优化公司
  • 泰安网站建设培训新闻网站软文平台
  • 公司做个网站seo网站推广费用
  • 视频网站企业网站系统
  • 网站是如何做的好沧浪seo网站优化软件
  • zencart 一个产品网站下单去了外包简历就毁了吗
  • 静态网站添加到织梦公司推广文案
  • 怎么做投资网站不违法卢镇seo网站优化排名
  • wordpress system.css如何提升网站seo排名
  • 做网站设计多少钱查域名注册详细信息查询
  • 南阳市做网站网页设计与网站开发
  • 中国商标官方网站网络营销推广的渠道有哪些
  • 做网站必须知道的问题短网址链接生成
  • 郑州网站seo服务网站搭建策略与方法
  • 表白二维码制作网站seo外链怎么做
  • 河南做网站多少钱知名品牌营销策略
  • 制作网站公司首 荐乐云seo百度客户端电脑版
  • 海尔网站建设投入提高百度搜索排名
  • 做装修效果图的网站有哪些软件下载广州谷歌seo
  • 专做韩国代购的网站深圳全网推广平台
  • 模拟人生4做游戏下载网站如何推广普通话
  • php的网站怎么做百度竞价排名榜
  • 给客户做网站需要提供最新实时大数据
  • jsp动态网站开发案...海外推广渠道
  • 温州手机网站制作哪家好网站seo搜索引擎的原理是什么