zoukankan      html  css  js  c++  java
  • 【BZOJ2083】[Poi2010]Intelligence test 二分

    【BZOJ2083】[Poi2010]Intelligence test

    Description

    霸中智力测试机构的一项工作就是按照一定的规则删除一个序列的数字,得到一个确定的数列。Lyx很渴望成为霸中智力测试机构的主管,但是他在这个工作上做的并不好,俗话说熟能生巧,他打算做很多练习,所以他希望你写一个程序来快速判断他的答案是否正确。

    Input

    第一行为一个整数m(1<=m<=1000000)第二行包括m个用空格分开的整数ai(1<=ai<=1000000),组成了最初的序列,第三行为一个整数n(1<=n<=1000000),表示n个Lyx经过一系列删除得到的序列,每个序列两行,第一行给出长度L(1<=L<=m),然后下一行为L个由空格分开的整数bi(1<=bi<=1000000)。

    Output

    共n行,如果Lyx的序列确实是由最初的序列删除一些数得到,就输出TAK,否则输出NIE。

    Sample Input

    7
    1 5 4 5 7 8 6
    4
    5
    1 5 5 8 6
    3
    2 2 2
    3
    5 7 8
    4
    1 5 7 4

    Sample Output

    TAK
    NIE
    TAK
    NIE

    题解:用vector维护每个数出现的所有位置,然后查询时在vector上二分即可。

    #include <cstdio>
    #include <cstring>
    #include <iostream>
    #include <vector>
    using namespace std;
    const int maxn=1000010;
    int n,m,len;
    vector<int> v[maxn];
    inline int rd()
    {
    	int ret=0,f=1;	char gc=getchar();
    	while(gc<'0'||gc>'9')	{if(gc=='-')f=-f;	gc=getchar();}
    	while(gc>='0'&&gc<='9')	ret=ret*10+gc-'0',gc=getchar();
    	return ret*f;
    }
    int main()
    {
    	m=rd();
    	int i,j,a,last,l,r,mid;
    	for(i=1;i<=m;i++)	a=rd(),v[a].push_back(i);
    	n=rd();
    	for(i=1;i<=n;i++)
    	{
    		len=rd(),last=0;
    		for(j=1;j<=len;j++)
    		{
    			a=rd();
    			if(last==-1)	continue;
    			l=0,r=v[a].size();
    			while(l<r)
    			{
    				mid=l+r>>1;
    				if(v[a][mid]>last)	r=mid;
    				else	l=mid+1;
    			}
    			if(r==v[a].size())	last=-1;
    			else	last=v[a][r];
    		}
    		if(last==-1)	printf("NIE
    ");
    		else	printf("TAK
    ");
    	}
    	return 0;
    }
  • 相关阅读:
    决策模型(一):不确定型决策法
    Redis系列(二):Redis的数据类型及命令操作
    Redis系列(一):Redis的简介与安装
    java中传值方式的个人理解
    理解主从设备模式(Master-Slave)
    基于ubuntu16.04部署IBM开源区块链项目-弹珠资产管理(Marbles)
    基于ubuntu16.04快速构建Hyperledger Fabric网络
    fastjson 的使用总结
    简析淘宝网的六大质量属性
    软件架构师如何工作
  • 原文地址:https://www.cnblogs.com/CQzhangyu/p/7434652.html
Copyright © 2011-2022 走看看