标签:描述 ensure 并集 UNC math name new script pts
已知有两个等长的非降序序列S1, S2, 设计函数求S1与S2并集的中位数。有序序列A?0??,A?1??,?,A?N?1??的中位数指A?(N?1)/2??的值,即第?(N+1)/2?个数(A?0??为第1个数)。
算法描述:通过将s1,s2合并并重新非降序排序得到一个新的数组b[2n],然后再输出它的中位数。
代码:
#include<iostream>
using namespace std;
int BiSort(int n,int a1[],int a2[]){
int *b= new int [2*n];
int i,j,k;
for(;;){
}
while(k<=2*n-1){
b[k++]=a1[i++];
}
cout<<b[n-1];
return b[n-1];
}
int main(){
int n;
cin>>n;
int *a1= new int [n];
int *a2= new int [n];
for(int i=0;i<n;i++){
cin>>a1[i];
}
for(int i=0;i<n;i++){
cin>>a2[i];
}
BiSort(n,a1,a2);
return 0;
}
4.时间复杂度为O(n),并非老师所要求的O(lgn),即二分法解决问题。空间复杂度为O(1)。
5.通过这次实践得知自己算法思想和编程能力远远不足,需要勤奋以弥补不足。
标签:描述 ensure 并集 UNC math name new script pts
原文地址:https://www.cnblogs.com/Evity/p/9823254.html