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

不需要登录的网页小游戏大连优化网站课程

不需要登录的网页小游戏,大连优化网站课程,企业所得税优惠政策最新2023计算,邯郸市网络科技有限公司给你一个下标从 0 开始的整数数组 nums 和一个整数 pivot 。请你将 nums 重新排列,使得以下条件均成立: 所有小于 pivot 的元素都出现在所有大于 pivot 的元素 之前 。 所有等于 pivot 的元素都出现在小于和大于 pivot 的元素 中间 。 小于 pivot 的元素…

给你一个下标从 0 开始的整数数组 nums 和一个整数 pivot 。请你将 nums 重新排列,使得以下条件均成立:

所有小于 pivot 的元素都出现在所有大于 pivot 的元素 之前 。
所有等于 pivot 的元素都出现在小于和大于 pivot 的元素 中间 。
小于 pivot 的元素之间和大于 pivot 的元素之间的 相对顺序 不发生改变。
更正式的,考虑每一对 pi,pj ,pi 是初始时位置 i 元素的新位置,pj 是初始时位置 j 元素的新位置。对于小于 pivot 的元素,如果 i < j 且 nums[i] < pivot 和 nums[j] < pivot 都成立,那么 pi < pj 也成立。类似的,对于大于 pivot 的元素,如果 i < j 且 nums[i] > pivot 和 nums[j] > pivot 都成立,那么 pi < pj 。
请你返回重新排列 nums 数组后的结果数组。

示例 1:

输入:nums = [9,12,5,10,14,3,10], pivot = 10
输出:[9,5,3,10,10,12,14]
解释:
元素 9 ,5 和 3 小于 pivot ,所以它们在数组的最左边。
元素 12 和 14 大于 pivot ,所以它们在数组的最右边。
小于 pivot 的元素的相对位置和大于 pivot 的元素的相对位置分别为 [9, 5, 3] 和 [12, 14] ,它们在结果数组中的相对顺序需要保留。
示例 2:

输入:nums = [-3,4,3,2], pivot = 2
输出:[-3,2,4,3]
解释:
元素 -3 小于 pivot ,所以在数组的最左边。
元素 4 和 3 大于 pivot ,所以它们在数组的最右边。
小于 pivot 的元素的相对位置和大于 pivot 的元素的相对位置分别为 [-3] 和 [4, 3] ,它们在结果数组中的相对顺序需要保留。

提示:

1 <= nums.length <= 105
-106 <= nums[i] <= 106
pivot 等于 nums 中的一个元素。

法一:按顺序保存下来小于pivot和大于pivot的数,再拼接:

class Solution {
public:vector<int> pivotArray(vector<int>& nums, int pivot) {vector<int> small;vector<int> big;int pivotNum = 0;for (int num : nums){if (num < pivot){small.push_back(num);}else if (num > pivot){big.push_back(num);}else{++pivotNum;}}for (int i = 0; i < pivotNum; ++i){small.push_back(pivot);}small.insert(small.end(), big.begin(), big.end());return small;}
};

如果nums的长度为n,此算法时间复杂度为O(n),空间复杂度为O(n)。

法二:直接在结果数组中构建答案,先正向遍历nums,把小于pivot的数按顺序放在左边,然后反向遍历nums,把大于pivot的数按顺序放在右边,中间填充pivot即可:

class Solution {
public:vector<int> pivotArray(vector<int>& nums, int pivot) {vector<int> ans(nums.size());int smallIndex = 0;for (int num : nums){if (num < pivot){ans[smallIndex++] = num;}}int bigIndex = nums.size() - 1;for (vector<int>::reverse_iterator it = nums.rbegin(); it != nums.rend(); ++it){if (*it > pivot){ans[bigIndex--] = *it;}}while (smallIndex <= bigIndex){ans[smallIndex++] = pivot;ans[bigIndex--] = pivot;}return ans;}
};

如果nums的长度为n,此算法时间复杂度为O(n),空间复杂度为O(1)。本解法也可以一遍正向遍历,把大于pivot的值在ans的最后从右往左排,最后再reverse一下大于pivot的值即可:

class Solution {
public:vector<int> pivotArray(vector<int>& nums, int pivot) {vector<int> ans(nums.size(), pivot);int smallIndex = 0;int bigIndex = nums.size() - 1;for (int num : nums){if (num < pivot){ans[smallIndex++] = num;}else if (num > pivot){ans[bigIndex--] = num;}}reverse(ans.begin() + bigIndex + 1, ans.end());return ans;}
};
http://www.yayakq.cn/news/318250/

相关文章:

  • 工程建设部网站徐州信息港
  • 网站关键词有哪些网站右侧信息跟随左侧菜单栏变化
  • 网站建设流建设工程项目
  • 无锡seo网站排名优化门户网站建设ppt方案
  • 旅游网站建设方案2019学校部门网站的建设
  • 怎样在网站模板上做修改游戏平台网站制作
  • 免费做电子请柬的网站网站做seo需要哪些准备
  • 海口专业网站搭建厂wordpress 模板层次结构信息图
  • 苏州建网站公司wordpress店铺主题
  • 建设项目备案网站莱芜在线论坛话题牛泉镇
  • 1m带宽做网站速度怎么样wordpress文章页尾添加信息
  • 网站定制公司选哪家最好免费观看高清播放
  • 江西省建设厅官方网站郴州市一中
  • 营销型网站建设报价方案网页购买
  • 西安电商网站湖北省建设招投标监督机构网站
  • 网站建设 排名宝下拉陕西省住房和城乡建设厅门户网站
  • 泸州中泸集团建设有限公司网站汉阳做网站
  • 做视频挣钱的网站19年做网站还能赚钱
  • 明星网站怎么设计制作营销网页
  • 网站建设个人网站装修公司十大排行榜
  • 绿园区建设局网站郑州百姓网官网
  • python 做网站模块网站首页psd格式怎么做
  • 网站百度忽然搜索不到扫码支付个人商城网站开发免费
  • 成都网站建设制作服务科技创新与应用
  • 网站制作教程 pdf下载wordpress 百万数据
  • 网站广告赚钱怎么做合同网站开发 设计 后期维护
  • 设计网站faq需注意如何查看网站所用空间
  • 亚马逊网站建设目的asp企业网站
  • 企业加强网站建设的必要性最近一周热点回顾
  • 长沙 外贸网站建设公司价格拖拽式制作网站