You are given two arrays of integers a and b. For each element of the second array bj you should find the number of elements in array a that are less than or equal to the value bj.
Input
The first line contains two integers n, m (1 ≤ n, m ≤ 2·105) — the sizes of arrays a and b.
The second line contains n integers — the elements of array a ( - 109 ≤ ai ≤ 109).
The third line contains m integers — the elements of array b ( - 109 ≤ bj ≤ 109).
Output
Print m integers, separated by spaces: the j-th of which is equal to the number of such elements in array a that are less than or equal to the value bj.
Examples
Input
5 4
1 3 5 7 9
6 4 2 8
Output
3 2 1 4
Input
5 5
1 2 1 2 5
3 1 4 1 5
Output
4 2 4 2 5
题目大意:
看个样例一吧:
第一行 有两个数 ,分别为数组a,b的大小;
第二三行分别为 a,b数组的数据 ;
求 在整个a数组元素中,比 b数组中第一个,第二个,,,,元素小的个数;
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <iostream>
#include<bits/stdc++.h>
using namespace std;
int main()
{
int n,m;
int a[200050];
int b[200050];
while(~scanf("%d %d", &n, &m))
{
for(int i=1;i<=n;i++)
{
scanf("%d", &a[i]);
}
for(int j=1;j<=m;j++)
{
scanf("%d", &b[j]);
}
sort(a+1, a+n+1);
for(int i=1;i<=m;i++)
{
if(i==m) printf("%d\n", upper_bound(a+1, a+n+1, b[i]));
else printf("%d ", upper_bound(a+1, a+n+1, b[i]));
}
}
return 0;
}
知识点:
lower_bound( )和upper_bound( )都是利用二分查找的方法在一个排好序的数组中进行查找的。
在从小到大的排序数组中,
lower_bound( begin,end,num):从数组的begin位置到end-1位置二分查找第一个大于或等于num的数字,找到返回该数字的地址,不存在则返回end。通过返回的地址减去起始地址begin,得到找到数字在数组中的下标。
upper_bound( begin,end,num):从数组的begin位置到end-1位置二分查找第一个大于num的数字,找到返回该数字的地址,不存在则返回end。通过返回的地址减去起始地址begin,得到找到数字在数组中的下标。
在从大到小的排序数组中,重载lower_bound()和upper_bound()
lower_bound( begin,end,num,greater() ):从数组的begin位置到end-1位置二分查找第一个小于或等于num的数字,找到返回该数字的地址,不存在则返回end。通过返回的地址减去起始地址begin,得到找到数字在数组中的下标。
upper_bound( begin,end,num,greater() ):从数组的begin位置到end-1位置二分查找第一个小于num的数字,找到返回该数字的地址,不存在则返回end。通过返回的地址减去起始地址begin,得到找到数字在数组中的下标。