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

青岛市建设工程信息网官网windows优化大师可以卸载吗

青岛市建设工程信息网官网,windows优化大师可以卸载吗,网站建设外包质量进度跟进,edu网站开发文章目录 前言一、704. 二分查找二、27. 移除元素三、34. 在排序数组中查找元素的第一个和最后一个位置总结 前言 这次是C; 代码随想录算法训练营第一天| 704. 二分查找、27. 移除元素_愚者__的博客-CSDN博客 (java) 一、704. 二分查找 的优…

文章目录

  • 前言
  • 一、704. 二分查找
  • 二、27. 移除元素
  • 三、34. 在排序数组中查找元素的第一个和最后一个位置
  • 总结

前言

这次是C;

代码随想录算法训练营第一天| 704. 二分查找、27. 移除元素_愚者__的博客-CSDN博客 (java)


一、704. 二分查找

+的优先级高于>>

int search(int* nums, int numsSize, int target){int left = 0;int right = numsSize-1;int middle = 0;while(left <= right){middle = left + ((right-left)>>1);if(nums[middle] > target){right = middle-1;}else if(nums[middle] <target){left = middle+1;}else if(nums[middle] == target){return middle;}}return -1;
}

二、27. 移除元素h

先赋值,后++;

int removeElement(int* nums, int numsSize, int val){int slow= 0;for(int fast = 0;fast<numsSize;fast++){if(val != nums[fast]){nums[slow] = nums[fast];// slow = slow + 1;slow ++;}}return slow;
}

三、34. 在排序数组中查找元素的第一个和最后一个位置

难点:

1.在于类型分类上,左右边界需要独自寻找;

2. 为什么会有“*returnSize = 2”,不太能理解它到底起什么作用;如果把这句删掉,后面的resNum就出不来结果;如果更改成“*returnSize = 1”,会只出现左右边界的一个

returnSize 是一个指针,它指向一个整数变量,该变量表示要返回的数组的大小。在 searchRange 函数中写 *returnSize = 2;,是在告诉调用者返回的数组 resNums 有两个元素。
这是 LeetCode 中 C 语言版本的函数参数约定,以便在函数返回一个数组时,调用者也能知道数组的大小。在许多其他编程语言中,例如 Python 或 Java,数组或列表自身包含长度信息,所以不需要这种约定。但在 C 中,纯数组并不知道自己的长度,所以需要一个额外的参数来传递这个信息。
在纯C中,数组不知道自己的大小,因此常见的方法是在函数返回一个数组时,通过一个额外的参数(通常是一个指针)来返回其大小。这是在很多传统的C库和应用程序中的常见模式。
LeetCode采用了这个模式,并为C语言解决方案设定了一个约定,要求函数除了返回数组外,还要通过一个额外的指针参数返回数组的大小。这样,LeetCode的判题系统就可以知道返回数组的实际大小,从而正确地评估解决方案。
所以,这是LeetCode为了清晰地得到结果信息而采用的约定,但这种约定在C语言的实践中是常见的。
在其他环境或自己的项目中,如果你没有提供一种告知数组长度的机制,你也会遇到同样的问题。C语言不提供自带的机制来确定动态分配的数组的大小,所以你需要自己跟踪它,或者使用某种约定(如数组的特殊值)来表示数组的结束。
因此,为了正确地处理数组和它的长度,你应该始终提供一个机制(无论是额外的参数、结构体还是其他方法)来传递数组的实际大小。

                                                                                                                      ——from 卡卡鱼

但是“returnSize = 2”,和后面的resNums没有关系啊,resNums是我们自己设置的:

leetcode里面  我们实现的函数最终要被调用的   外面的函数会使用这个变量(returnSize)来得到searchRange()返回的数组的大小;

                                                                           ——from Go\C++-Nefelibata-华中农大研三

代码:

int* searchRange(int* nums, int numsSize, int target, int* returnSize){int leftBorder = searchLeftBorder(nums,numsSize,target);int rightBorder = searchRightBorder(nums,numsSize,target);*returnSize = 2;int *resNums = (int*)malloc(sizeof(int) * 2);resNums[0] = leftBorder;resNums[1] = rightBorder;return resNums;
}int searchLeftBorder(int *nums,int numsSize,int target){int left = 0;int right = numsSize-1;int leftBorder = -1;while(left <= right){int middle = left + ((right-left)>>1);if(nums[middle] == target){leftBorder = middle;right = middle - 1;}else if (nums[middle] > target) {right = middle - 1;} else {left = middle + 1;}}return leftBorder;
}int searchRightBorder(int *nums,int numsSize,int target){int left = 0;int right = numsSize-1;int rightBorder = -1;while(left <= right){int middle = left + ((right-left)>>1);if(nums[middle] == target){rightBorder = middle;left = middle + 1;}else if (nums[middle] > target) {right = middle - 1;} else {left = middle + 1;}}return rightBorder;
}

总结

java转C语言,进步很大,开心。

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

相关文章:

  • wordpress 环保主题杭州seo培训
  • 秦皇岛做网站外包百度自媒体怎么注册
  • 贝尔利网站精准营销及推广
  • 做棋牌网站的步骤网络推广营销方式
  • idc销售网站源码环球军事网
  • 网站设计与建设报告免费推广引流平台有哪些
  • 个人网站做音乐网要备文化今日资讯最新消息
  • 怎么做网页web无锡seo优化
  • 政府网站安全建设总结sem和seo有什么区别
  • 前端网站建设和维护河北seo网络优化师
  • 网站建设丶金手指花总11游戏推广员一个月能赚多少
  • 大学生个人简历模板免费365优化大师软件下载
  • 如何建设公司门户网站墨子学院seo
  • 广州网站优化注意事项seo技术培训班
  • 厂家直销网站建设软文营销定义
  • 网站建设肆金手指排名6sem模型
  • dz做分类网站网络运营主要做什么工作
  • 郑州高新区网站建设seo搜索引擎工具
  • 网站建设代理哪个好搜索引擎下载入口
  • 国外ps教程网站本地推荐本地推荐
  • 本机建的网站打开却很慢东莞百度推广优化
  • 免费建设网站的好么百度网址链接是多少
  • 浙江省水利建设行业协会网站广东做seo的公司
  • 有哪些网站可以免费做推广长沙关键词快速排名
  • 网站建设与营销服务最近的新闻大事10条
  • 做销售网站需要多少钱快速整站排名seo教程
  • 美团做团购网站nba最新交易消息
  • 网上签到做任务赚钱的网站怎么优化网站
  • 普陀网站建设公司软件开发培训机构排名
  • 展馆展示设计公司排名免费关键词优化排名软件