蓝桥杯 经典算法题 合并排序数组

题目:

题解:

leetcode上也有这道题一模一样。和归并排序的小过程基本一模一样,只不过因为题目要求只能将arr2中元素合并到arr1中,一种可行的方法是按元素从大到小,顺序从每个序列尾部开始操作,第一填的位置是arr1的尾部,第一个判断的是arr1中有元素的尾部和arr2中有元素的尾部,和归并一模一样的过程构造出一个单调的数组。

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int main(){
  int a,b;
  cin>>a>>b;
  vector<int>arr1(a),arr2(a-b);
  for(int i=0;i<b;i++)cin>>arr1[i];
  for(int i=0;i<a-b;i++)cin>>arr2[i];
  int x=b-1,y=a-b-1,k=a-1;
  while(x>=0||y>=0){
    if(y<0||(x>=0&&arr1[x]>=arr2[y])){
      arr1[k--]=arr1[x--];
    }else {
      arr1[k--]=arr2[y--];
    }
  }
  for(auto x:arr1){
    cout<<x<<" ";
  }
  return 0;
}
相关推荐
小则又沐风a14 分钟前
类和对象(C++)---上
java·c++·算法
季明洵19 分钟前
动态规划及背包问题
java·数据结构·算法·动态规划·背包问题
busideyang25 分钟前
函数指针类型定义笔记
c语言·笔记·stm32·单片机·算法·嵌入式
Wect27 分钟前
LeetCode 215. 数组中的第K个最大元素:大根堆解法详解
前端·算法·typescript
蒸汽求职27 分钟前
【蒸汽教育求职干货】OPT只剩3个月还没找到工作,怎么办?——留学生IT求职的“紧急预案”
人工智能·经验分享·面试·职场和发展·美国求职
蒸汽求职30 分钟前
【蒸汽教育求职分享】美国IT面试的Behavioral Question:STAR法则人人都知道,但90%的人用错了
人工智能·面试·职场和发展·github·求职招聘·留学生求职
深邃-38 分钟前
数据结构-双向链表
c语言·开发语言·数据结构·c++·算法·链表·html5
2401_8785302139 分钟前
分布式任务调度系统
开发语言·c++·算法
中小企业实战军师刘孙亮41 分钟前
什么是增长陷阱?中小企业“增长陷阱”破局指南-佛山鼎策创局破局增长咨询
职场和发展·新媒体运营·创业创新·需求分析·内容运营
_深海凉_1 小时前
LeetCode热题100-两数之和
算法·leetcode·职场和发展