are you ok?
题号:NC15949
时间限制:C/C++/Rust/Pascal 2秒,其他语言4秒
空间限制:C/C++/Rust/Pascal 128 M,其他语言256 M
64bit IO Format: %lld

题目描述

一个长度为n的数组a,数组下标从0开始。现在要求你查询从左到右第一个不小于k的数字a[i], 输出i,并且马上把a[i-1]++;如果你找到的a[i]中的i等于0,那么a[0-1]是非法的,因此只要输出i就行了,不进行a[i-1]++;如果你在数组中找不到一个数字不小于k,则输出”are you ok ”

输入描述:

多组输入,输入直到遇到EOF为止;

第一行输入两个整数n和q,表示数组a中有n个整数,q表示q次查询;

第二行输入n个整数;

第三行到后2+q行,每行输入一个数字k,表示要求你查询从左到右第一个不小于k的数字并马上输出。

注意:1 < n, q <= 1e6, a[i]和k是一个int型的整数

输出描述:

见输入。
示例1

输入

复制
3 4
1 2 8
2
2
8
9

输出

复制
1
0
2
are you ok