zoukankan      html  css  js  c++  java
  • 2019 计蒜之道 初赛 第六场

    A.

    https://nanti.jisuanke.com/t/39455

    VIPKID 是全球增长速度最快的在线青少儿英语教育品牌,纯北美外教 11 对 11 在线授课,通过互联网的方式将中国小朋友与北美老师连接起来。VIPKID 为了帮每个孩子找到最适合自己的外教老师,会对外教在教学上的语言、技能等多层维度划定数百个标签,再结合智能算法进行师生匹配,向学员推荐最合适其本人的外教。

    VIPKID 通过大数据和标签来智能地进行师生匹配。当我们把标签抽象成括号 ( ),匹配过程简化为括号串的匹配,希望聪明的你来解决如下问题:判断给定的括号序列是否合法且反回文。

    对于这样标签抽象组成的括号序列,我们有如下定义:

    合法的的括号序列:

    • 空序列;
    • 如果AA、BB是合法的括号序列,那么(A)(A)和ABAB都是合法的括号序列;

    反回文的括号序列:如果序列长度为 LL,且字符从 00 开始编号,那么任意的 S[i]S[i] 和 S[L-i-1]S[Li1] 对应的字符应该不同。(i 的取值范围 0≤i≤L1 )

    输入格式

    一行一个字符串 SS。

    输出格式

    如果是合法且反回文的串,输出 "YES",否则输出 "NO"。(均无双引号)

    数据规模

    SS 长度小于10^1e6

    样例输入1

    ()()()

    样例输出1

    YES

    样例输入2

    ()(())

    样例输出2

    NO
    题意:括号匹配+判断反回文
     1 #include <bits/stdc++.h>
     2 
     3 using namespace std;
     4 
     5 int main()
     6 {
     7     ios::sync_with_stdio(0);
     8     cin.tie(0);
     9     cout.tie(0);
    10 
    11     string str;
    12     bool kuohao,fanhuiwen;
    13     stack<char> sc;
    14     //while(cin>>str){
    15     cin>>str;
    16         kuohao=true;
    17         fanhuiwen=true;
    18         char tmp;
    19         for(int i=0;i<str.size();i++){
    20             if(str[i]=='('){
    21                 sc.push(str[i]);
    22             }else if(str[i]==')'){
    23                 if(sc.empty()){
    24                     kuohao=false;
    25                     break;
    26                 }else{
    27                     tmp=sc.top(); sc.pop();
    28                     if(tmp=='('){
    29                         continue;
    30                     }else{
    31                         kuohao=false;
    32                         break;
    33                     }
    34 
    35                 }
    36             }
    37         }
    38         if(!sc.empty()) kuohao=false;
    39 
    40         int strlen=str.size();
    41         for(int i=0;i<=strlen/2;i++){
    42             if(str[i]==str[strlen-i-1]){
    43                 fanhuiwen=false;
    44                 break;
    45             }
    46         }
    47         if(kuohao&&fanhuiwen){
    48             cout<<"YES"<<endl;
    49         }else{
    50             cout<<"NO"<<endl;
    51         }
    52     //}
    53     return 0;
    54 }
    View Code

    BC.

    https://nanti.jisuanke.com/t/39457

    样例输入

    3
    1 3 5
    0 1 2
    5
    1 2 3 4 5

    样例输出

    0 1 1 2 2

    题意: 按公式暴力,注意用long long 。

     1 #include <bits/stdc++.h>
     2 
     3 using namespace std;
     4 
     5 long long a[1000005],b[1000005],q[1000005];
     6 long long resu[1000005];
     7 
     8 int main()
     9 {
    10     ios::sync_with_stdio(0);
    11     cin.tie(0);
    12     cout.tie(0);
    13 
    14     int n,Q;
    15     cin>>n;
    16     for(int i=0;i<n;i++){
    17         cin>>a[i];
    18     }
    19     for(int i=0;i<n;i++){
    20         cin>>b[i];
    21     }
    22     cin>>Q;
    23     for(int i=0;i<Q;i++){
    24         cin>>q[i];
    25     }
    26     long long minn=1e19;
    27     for(int i=0;i<Q;i++){
    28         minn=1e19;
    29         long long tmp=0;
    30         for(int j=0;j<n;j++){
    31             long long chengji=(q[i]-a[j]);
    32             tmp=chengji*chengji+b[j];
    33             minn=min(minn,tmp);
    34         }
    35         resu[i]=minn;
    36     }
    37     for(int i=0;i<Q;i++){
    38         cout<<resu[i]<<" ";
    39     }
    40     return 0;
    41 }
    View Code

    D:未做

  • 相关阅读:
    记2008年7月25日午后 心情
    [多媒体]词典编码
    [多媒体]算术编码、游程编码
    [多媒体]数据压缩的类型
    [多媒体]理解PCM、DPCM、APCM、ADPCM
    C++异常处理
    [转]linux上SVN解决冲突的办法
    从海量数据查找有或者没有出现的数据
    八数码问题
    [转]linux中强大的screen命令
  • 原文地址:https://www.cnblogs.com/TWS-YIFEI/p/10993351.html
Copyright © 2011-2022 走看看