博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Sereja and Suffixes(思维)
阅读量:5037 次
发布时间:2019-06-12

本文共 1996 字,大约阅读时间需要 6 分钟。

Sereja and Suffixes
Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u
 

Description

Sereja has an array a, consisting of n integers a1, a2, ..., an. The boy cannot sit and do nothing, he decided to study an array. Sereja took a piece of paper and wrote out m integers l1, l2, ..., lm(1 ≤ li ≤ n). For each number li he wants to know how many distinct numbers are staying on the positions li, li + 1, ..., n. Formally, he want to find the number of distinct numbers among ali, ali + 1, ..., an.?

Sereja wrote out the necessary array elements but the array was so large and the boy was so pressed for time. Help him, find the answer for the described question for each li.

Input

The first line contains two integers n and m(1 ≤ n, m ≤ 105). The second line contains n integers a1, a2, ..., an(1 ≤ ai ≤ 105) — the array elements.

Next m lines contain integers l1, l2, ..., lm. The i-th line contains integer li(1 ≤ li ≤ n).

Output

Print m lines — on the i-th line print the answer to the number li.

Sample Input

Input
10 10 1 2 3 4 1 2 3 4 100000 99999 1 2 3 4 5 6 7 8 9 10
Output
6 6 6 6 6 5 4 3 2 1 题解:让求x到n的不同数字的个数;打表,对于m次询问,如果每次都暴力肯定超了,由于n是固定的,所以打下表,从后往前; 代码:
#include
#include
#include
#include
#include
#include
#include
using namespace std;const int MAXN = 1e5+100;class Ary{ public: int n,m; int a[MAXN]; int dp[MAXN]; set
st; Ary(int n,int m):n(n),m(m){ for(int i = 1; i <= n; i++){ cin >> a[i]; } } int work(){ int cnt = 0; for(int i = n; i >= 1; i--){ if(!st.count(a[i])){ cnt++; st.insert(a[i]); } dp[i] = cnt; } //cout << endl; } ~Ary(){ //cout << "对象毁灭" << endl; }};int main(){ int n,m; while(~scanf("%d%d", &n, &m)){ Ary boy(n,m); int temp; boy.work(); while(m--){ scanf("%d",&temp); printf("%d\n",boy.dp[temp]); } } return 0;}

 

转载于:https://www.cnblogs.com/handsomecui/p/5343909.html

你可能感兴趣的文章
oracle入门(4)——少而常用的命令
查看>>
打印机设置(PrintDialog)、页面设置(PageSetupDialog) 及 RDLC报表如何选择指定打印机...
查看>>
Java 虚拟机部分面试题
查看>>
二叉树的遍历问题总结
查看>>
Spring之面向切面编程AOP
查看>>
MATLAB GUI程序设计中使文本框接收多行输入的方法
查看>>
全文检索-Elasticsearch (四) elasticsearch.net 客户端
查看>>
Oracle DBMS_SESSION
查看>>
sublime复制当前行到下一行
查看>>
WPF 3D变换应用
查看>>
ArchLinux安装开源VMware Tools
查看>>
DB2 锁升级示例1
查看>>
16.RDD实战
查看>>
MainFrame知识小结(20120210)—dfsort/syncsort中的数据类型
查看>>
D - Flip tile
查看>>
Java连接RabbitMQ之创建连接
查看>>
开户vim编程之--cscope支持
查看>>
python数据类型图解
查看>>
C#微信登录-手机网站APP应用
查看>>
HTML5实践 -- iPhone Safari Viewport Scaling Bug
查看>>