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

题目:

题解:

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;
}
相关推荐
想唱rap26 分钟前
C++ map和set
linux·运维·服务器·开发语言·c++·算法
小欣加油2 小时前
leetcode 1018 可被5整除的二进制前缀
数据结构·c++·算法·leetcode·职场和发展
无敌最俊朗@2 小时前
链表-力扣hot100-随机链表的复制138
数据结构·leetcode·链表
WWZZ20253 小时前
快速上手大模型:深度学习12(目标检测、语义分割、序列模型)
深度学习·算法·目标检测·计算机视觉·机器人·大模型·具身智能
Andrew_Ryan3 小时前
llama.cpp Build Instructions
算法
玖剹3 小时前
递归练习题(四)
c语言·数据结构·c++·算法·leetcode·深度优先·深度优先遍历
做人不要太理性3 小时前
【Linux系统】线程的同步与互斥:核心原理、锁机制与实战代码
linux·服务器·算法
向阳逐梦3 小时前
DC-DC Buck 电路(降压转换器)全面解析
人工智能·算法
Mz12213 小时前
day04 小美的区间删除
数据结构·算法