#include <iostream>
#include <cmath>
#include <vector>
#include <string.h>
#include <bits/stdc++.h>
#include <cstdlib>
#include <time.h>
#include <fstream>
#include <iterator>
#include <utility>
#include <algorithm>
#include <set>
#include <map>
#include <bitset>
using namespace std;
#define ll long long
#define ull unsigned ll
#define ld long double
typedef vector<int> vi;
typedef multiset<int> mi;
typedef multiset<ll> mll;
typedef vector<ll> vll;
typedef vector<bool> vb;
typedef vector<string> vs;
typedef vector<vector<int>> _2vi;
typedef vector<vector<ll>> _2vll;
#define all(v) ((v).begin()), ((v).end())
#define sz(v) ((ll)((v).size()))
#define vinp(v, n) \
for (ull i = 0; i < (n); i++) \
cin >> (v)[i]
#define printv(v) \
for (auto i : (v)) \
cout << i << " "
#define fr0(i, n) for (ull(i) = 0; (i) < (n); (i)++)
#define fr1(i, n) for (ull(i) = 1; (i) < (n); (i)++)
#define fr(i, x, n) for (ull(i) = (x); (i) < (n); (i)++)
#define _CRT_SECURE_NO_WARNING
const ll MOD = 1000000007;
void Bustany() {
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
#ifndef ONLINE_JUDGE
freopen("./in.txt", "r", stdin), freopen("./out.txt", "w", stdout);
#endif
}
void solve() {
ll n, m;
cin >> n >> m;
vll a(n), b(m);
vinp(a, n);
vinp(b, m);
vll c={all(b)};
sort(all(a));
sort(all(b), greater<ll>());
stack<ll> st;
map<ll,ll> mp;
for (ll i = 0; i < n; i++) {
st.push(i);
}
for (int i = 0; i < m; i++) {
while (!st.empty() && b[i] < a[st.top()]) {
st.pop();
}
mp[b[i]]=st.size();
}
for(auto i:c){
cout << mp[i]<<" ";
}
}
int main() {
Bustany();
ll t = 1;
// cin >> t;
while (t--) {
solve();
}
}
I2luY2x1ZGUgPGlvc3RyZWFtPgojaW5jbHVkZSA8Y21hdGg+CiNpbmNsdWRlIDx2ZWN0b3I+CiNpbmNsdWRlIDxzdHJpbmcuaD4KI2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CiNpbmNsdWRlIDxjc3RkbGliPgojaW5jbHVkZSA8dGltZS5oPgojaW5jbHVkZSA8ZnN0cmVhbT4KI2luY2x1ZGUgPGl0ZXJhdG9yPgojaW5jbHVkZSA8dXRpbGl0eT4KI2luY2x1ZGUgPGFsZ29yaXRobT4KI2luY2x1ZGUgPHNldD4KI2luY2x1ZGUgPG1hcD4KI2luY2x1ZGUgPGJpdHNldD4KCnVzaW5nIG5hbWVzcGFjZSBzdGQ7CgojZGVmaW5lIGxsIGxvbmcgbG9uZwojZGVmaW5lIHVsbCB1bnNpZ25lZCBsbAojZGVmaW5lIGxkIGxvbmcgZG91YmxlCnR5cGVkZWYgdmVjdG9yPGludD4gdmk7CnR5cGVkZWYgbXVsdGlzZXQ8aW50PiBtaTsKdHlwZWRlZiBtdWx0aXNldDxsbD4gbWxsOwp0eXBlZGVmIHZlY3RvcjxsbD4gdmxsOwp0eXBlZGVmIHZlY3Rvcjxib29sPiB2YjsKdHlwZWRlZiB2ZWN0b3I8c3RyaW5nPiB2czsKdHlwZWRlZiB2ZWN0b3I8dmVjdG9yPGludD4+IF8ydmk7CnR5cGVkZWYgdmVjdG9yPHZlY3RvcjxsbD4+IF8ydmxsOwojZGVmaW5lIGFsbCh2KSAoKHYpLmJlZ2luKCkpLCAoKHYpLmVuZCgpKQojZGVmaW5lIHN6KHYpICgobGwpKCh2KS5zaXplKCkpKQoKI2RlZmluZSB2aW5wKHYsIG4pICAgICAgICAgICAgICAgIFwKICAgIGZvciAodWxsIGkgPSAwOyBpIDwgKG4pOyBpKyspIFwKICAgIGNpbiA+PiAodilbaV0KI2RlZmluZSBwcmludHYodikgICAgICBcCiAgICBmb3IgKGF1dG8gaSA6ICh2KSkgXAogICAgY291dCA8PCBpIDw8ICIgIgojZGVmaW5lIGZyMChpLCBuKSBmb3IgKHVsbChpKSA9IDA7IChpKSA8IChuKTsgKGkpKyspCiNkZWZpbmUgZnIxKGksIG4pIGZvciAodWxsKGkpID0gMTsgKGkpIDwgKG4pOyAoaSkrKykKI2RlZmluZSBmcihpLCB4LCBuKSBmb3IgKHVsbChpKSA9ICh4KTsgKGkpIDwgKG4pOyAoaSkrKykKI2RlZmluZSBfQ1JUX1NFQ1VSRV9OT19XQVJOSU5HCmNvbnN0IGxsIE1PRCA9IDEwMDAwMDAwMDc7Cgp2b2lkIEJ1c3RhbnkoKSB7CiAgICBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKGZhbHNlKTsKICAgIGNpbi50aWUoTlVMTCk7CiAgICBjb3V0LnRpZShOVUxMKTsKI2lmbmRlZiBPTkxJTkVfSlVER0UKICAgIGZyZW9wZW4oIi4vaW4udHh0IiwgInIiLCBzdGRpbiksIGZyZW9wZW4oIi4vb3V0LnR4dCIsICJ3Iiwgc3Rkb3V0KTsKI2VuZGlmCn0KCnZvaWQgc29sdmUoKSB7CiAgICBsbCBuLCBtOwogICAgY2luID4+IG4gPj4gbTsKICAgIHZsbCBhKG4pLCBiKG0pOwogICAgdmlucChhLCBuKTsKICAgIHZpbnAoYiwgbSk7CiAgICB2bGwgYz17YWxsKGIpfTsKICAgIHNvcnQoYWxsKGEpKTsKICAgIHNvcnQoYWxsKGIpLCBncmVhdGVyPGxsPigpKTsKICAgIHN0YWNrPGxsPiBzdDsKICAgIG1hcDxsbCxsbD4gbXA7CiAgICBmb3IgKGxsIGkgPSAwOyBpIDwgbjsgaSsrKSB7CiAgICAgICAgc3QucHVzaChpKTsKICAgIH0KICAgIGZvciAoaW50IGkgPSAwOyBpIDwgbTsgaSsrKSB7CiAgICAgICAgd2hpbGUgKCFzdC5lbXB0eSgpICYmIGJbaV0gPCBhW3N0LnRvcCgpXSkgewogICAgICAgICAgICBzdC5wb3AoKTsKICAgICAgICB9CiAgICAgICAgbXBbYltpXV09c3Quc2l6ZSgpOwogICAgfQogICAgZm9yKGF1dG8gaTpjKXsKICAgICAgICBjb3V0IDw8IG1wW2ldPDwiICI7CiAgICB9Cn0KCmludCBtYWluKCkgewogICAgQnVzdGFueSgpOwogICAgbGwgdCA9IDE7Ci8vICAgICBjaW4gPj4gdDsKICAgIHdoaWxlICh0LS0pIHsKICAgICAgICBzb2x2ZSgpOwogICAgfQp9