1.4.1 好多好多道符(cin/cout解绑,O3优化)

本文探讨了C++和Python在处理大量数据时的效率差异,以及在实际应用中如何选择合适的语言。通过示例展示了C++的unordered_map与Python的字典操作速度对比,并分析了输入输出性能。对于大型项目,C++的预编译优化如O3及cin/cout的同步关闭能显著提升运行速度。
摘要由CSDN通过智能技术生成

1.4.1 好多好多道符

Description

云之界是一个拥有着道法的世界,这个世界拥有着各种各样的魔法。

曾经有位大贤,将各种仙法编纂进了《道法三千》的书中,并给每种道法一个编号。书名虽然唤作《道法三千》,但是实际上的道法数远远超过三千,这本书现在已经是云之界广泛流行,于是,各大门派都使用这本书中的道法编号来标识道法。

小云是修行世家,然而天赋奇差,难以修习道法。所幸小云拥有大量家族赐予的道符,使用道符可以直接使用道法。

每张道符上有一个道法编号,代表这张道符可以直接使用出来的道法。

小云心中有qqq个诸如“ bib_ibi​ 道法我能否使用”的问题。由于小云的道符和疑问太多了,所以,它需要神奇的你来帮助他。

Input

第一行一个整数 n n n 。表示道符张数。

第二行 n n n 个以空格隔开的整数,第i个数表示 ai a_i ai​ 。含义见题目描述。

第三行一个正整数 q q q . 表示小云的疑问数。

第四行 q q q 个以空格隔开的正整数,第i个数表示  bi b_i bi​  。含义见题目描述。

Output

输出仅一行,为一个长度为nnn的字符串s。当小云可以使用出道法bib_ibi​时输出si=s_i=si​='Y',否则 si=s_i=si​= ‘N’.

Sample Input 1

10
5 5 6 8 8 9 12 23 41 79
15
50 8 9 23 233 5 6 8 79 12 5 8 9 41 22

Sample Output 1

NYYYNYYYYYYYYYN

Hint

数据范围:

50%的数据有:1≤n,q≤5000

100%的数据有:1≤n,q≤106

1≤ai​,bi​≤ 2^31−1

unordered_map<string,int> ump有三组测试点过不了,unordered_map<int,int> ump 能AC,究竟是scanf比cin快,还是什么原因。

现在搞清楚了,应当就是scanf比cin快。但是咱们也可以对cin/cout进行优化,需要再函数里面写上这两句代码:

std::ios::sync_with_stdio(false);//有了这两句之后就不能使用printf,scanf
std::cin.tie(0);

在主函数前加上O3优化,会更快一步,特别是对STL容器来说更为明显,虽说还没有去验证,不过先记录下来再说吧。
#pragma GCC optimize(3)

/** // 三个测试点过不了
#include <iostream>
#include <cstdio>
#include <unordered_map>
#include <string>
using namespace std;

int main()
{
    int n,p;
    scanf("%d",&n);
    unordered_map<string,int> ump;
    string str;
    for(int i=0;i<n;++i)
    {
        cin >> str;
        ump[str]=1;
    }
    scanf("%d",&p);
    for(int i=0;i<p;++i)
    {
        cin >> str;
        if(ump[str]==1)
            printf("Y");
        else
            printf("N");

    }
    return 0;
}
*/

//能AC
/**
#include <iostream>
#include <cstdio>
#include <unordered_map>
#include <string>
using namespace std;

int main()
{
    int n,p;
    scanf("%d",&n);
    unordered_map<int,int> ump;
    int val;
    for(int i=0;i<n;++i)
    {
        scanf("%d",&val);
        ump[val]=1;
    }
    scanf("%d",&p);
    for(int i=0;i<p;++i)
    {
        scanf("%d",&val);
        if(ump[val]==1)
            printf("Y");
        else
            printf("N");
    }
    return 0;
}

*/

//题目给的题解
#include <stdio.h>
#include <string>
using namespace std;
int a[1001000];
int n,q,b;
string S;
//直接二分
int find(int x)
{
    int mid,l=1,r=n;
  while(l<=r)
  {
    mid=(l+r)/2;
 	if(a[mid]>x)			//objective1 如何二分?(真的再给提示就直接是代码了QWQ --Megumin)
       r=mid-1;
    else if(a[mid]<x)
      l=mid+1;
    else
      return mid;
  }
    return -1;// Not found
}
int main()
{
    scanf("%d",&n);
    for(int i = 1;i <= n;i ++)
        scanf("%d",&a[i]);
    scanf("%d",&q);
    for(int i = 1;i <= q;i ++){
        scanf("%d",&b);
        if(find(b) != -1)
            S += 'Y';
        else
            S += 'N';
    }
    printf("%s\n",S.c_str());
}

/**
    4)//对cin/cout进行解绑,提高cin/cout的速度;
    能AC;
*/

#include <iostream>
#include <unordered_map>
#include <string>
using namespace std;

#pragma GCC optimize(3)
int main()
{
    std::ios::sync_with_stdio(false);//有了这两句之后就不能使用printf,scanf
    std::cin.tie(0);
    int n,p;
    cin >> n;
    unordered_map<string,int> ump;
    string str;
    for(int i=0;i<n;++i)
    {
        cin >> str;
        ump[str]=1;
    }

    cin >> p;
    for(int i=0;i<p;++i)
    {
        cin >> str;
        if(ump[str]==1)
            cout << 'Y';
        else
            cout << 'N';
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值