zoukankan      html  css  js  c++  java
  • PAT1033

    旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及坏掉的那些键,打出的结果文字会是怎样?

    输入格式:

    输入在2行中分别给出坏掉的那些键、以及应该输入的文字。其中对应英文字母的坏键以大写给出;每段文字是不超过105个字符的串。可用的字符包括字母[a-z, A-Z]、数字0-9、以及下划线“_”(代表空格)、“,”、“.”、“-”、“+”(代表上档键)。题目保证第2行输入的文字串非空。

    注意:如果上档键坏掉了,那么大写的英文字母无法被打出。

    输出格式:

    在一行中输出能够被打出的结果文字。如果没有一个字符能被打出,则输出空行。(坑点二:输出空行就是什么都不输出 跳过输出环节)

    # include<iostream>
    # include<algorithm>
    # include<stdio.h>
    # include<string>
    using namespace std;
    int main()
    {
        string a,b;
        getline(cin,a);   //坑点一:第一个字符串可能是个空行,就是说什么键都没坏掉.这时候不能用cin输入 要用getkine
        cin>>b;
        int i,j;
        for(i=0;i<a.length();i++)
        {
               if(a[i]=='+')
               {
                    for(j=0;j<b.length();j++)
               {
                      if(b[j]=='+' || (b[j]>='A' && b[j]<='Z'))
                      {
                            b[j]='#';     
                   }
                }      
           }
           else if(a[i]>='A' && a[i]<='Z')
           {
                   for(j=0;j<b.length();j++)
                {
                      if(a[i]==b[j])
                      {
                            b[j]='#';     
                   }
                   if(a[i]+32==b[j])
                   {
                           b[j]='#';
                   }
                 }      
           }
           else
           {
                 for(j=0;j<b.length();j++)
                {
                      if(a[i]==b[j])
                      {
                            b[j]='#';     
                   }
                 }      
           }
        }
    
        for(i=0;i<b.length();i++)
        {
               if(b[i]!='#')
               {
                     cout<<b[i];  
                   
           }
        }
        
        return 0;
    }

    输入样例:

    7+IE.
    7_This_is_a_test.
    

    输出样例:

    _hs_s_a_tst
  • 相关阅读:
    1837. Isenbaev's Number(floyd)
    1414. Astronomical Database(STL)
    1067. Disk Tree(字符串)
    1682. Crazy Professor(并查集)
    1650. Billionaires(线段树)
    1316. Electronic Auction(树状数组)
    1701. Ostap and Partners(并查集-关系)
    大数字运算——2、BigDecimal
    大数字运算——1、BigInteger
    java中的访问修饰符2
  • 原文地址:https://www.cnblogs.com/wshyj/p/6294757.html
Copyright © 2011-2022 走看看