zoukankan      html  css  js  c++  java
  • AC日记——紧急措施 openjudge 1.7 22

    22:紧急措施

    总时间限制: 
    1000ms
     
    内存限制: 
    65536kB
    描述

    近日,一些热门网站遭受黑客入侵,这些网站的账号、密码及email的数据惨遭泄露。你在这些网站上注册若干账号(使用的用户名不一定相同),但是注册时使用了相同的email。你此时拿到了那份泄露的数据,希望尽快将自己的密码更改。策略如下:根据email找到你的用户名和密码,然后更改密码。更改的规则为:小写和大写交换,非字母字符保持不变。

    输入
    第一行为你的email地址,长度不超过50个字符且只包含字母、数字和‘@’符号。
    第二行为账号数N,N(0 < N < 10000)。
    接下来N行,每行表示一个账号,格式为:
    用户名 密码 email
    它们之间用单个空格分开。用户名、密码、email均不含空格,且长度不超过50个字符。
    输出
    有若干行,每行为你的一个账号,包括:你的账号,修改后的密码(之间用单个空格分隔)。
    如果没有你的账号,则输出empty。
    样例输入
    样例输入1:
    abc@pku.edu.cn
    5
    helloKitty iLoveCats abc@pku.edu.cn
    2012 maya2012 cplusplus@exam.com
    KittyCat 5iKitty abc@pku.edu.cn
    program password teacher@exam.com
    whoAmi Feb.29$ abc@pku.edu.cn
    
    样例输入2:
    abc@pku.edu.cn
    1
    2012 maya2012 cplusplus@exam.com
    样例输出
    样例输出1:
    helloKitty IlOVEcATS
    KittyCat 5IkITTY
    whoAmi fEB.29$
    
    样例输出2:
    empty
    来源
    医学部计算概论2011年期末考试(谢佳亮)

    思路:

      大模拟;

    来,上代码:

    #include<cstdio>
    #include<string>
    #include<cstring>
    #include<iostream>
    
    using namespace std;
    
    struct node {
        char name[51],password[51],email[51];
    };
    struct node pro[10001];
    
    int n,num[10001],ans=0,len[10001],len_1;
    
    char word_email[51];
    
    inline void work(int now)
    {
        bool if_true=true;
        for(int i=0;i<len_1;i++)
        {
            if(pro[now].email[i]==word_email[i]) continue;
            if_true=false;
            break;
        }
        if(if_true) num[++ans]=now;
    }
    
    inline void char_(char &char__)
    {
        if(char__>='a'&&char__<='z') char__-=32;
        else if(char__>='A'&&char__<='Z') char__+=32;
    }
    
    int main()
    {
        cin>>word_email;
        len_1=strlen(word_email);
        cin>>n;
        for(int i=1;i<=n;i++)
        {
            cin>>pro[i].name>>pro[i].password>>pro[i].email;
            len[i]=strlen(pro[i].email);
            if(len[i]==len_1) work(i);
        }
        if(ans==0) printf("empty
    ");
        else
        {
            for(int i=1;i<=ans;i++)
            {
                cout<<pro[num[i]].name<<" ";
                int cur_1=strlen(pro[num[i]].password);
                for(int j=0;j<cur_1;j++)
                {
                    char_(pro[num[i]].password[j]);
                    putchar(pro[num[i]].password[j]);
                }
                putchar('
    ');
            }
        }
        return 0;
    }
  • 相关阅读:
    实验六
    派生类构造函数的理解
    实验五
    随机数
    面向行的输入(随时添加新的理解)
    实验四
    循序渐进VUE+Element 前端应用开发(21)--- 省市区县联动处理的组件使用(转载)
    循序渐进VUE+Element 前端应用开发(20)--- 使用组件封装简化界面代码(转载)
    循序渐进VUE+Element 前端应用开发(19)--- 后端查询接口和Vue前端的整合(转载)
    循序渐进VUE+Element 前端应用开发(18)--- 功能点管理及权限控制 (转载)
  • 原文地址:https://www.cnblogs.com/IUUUUUUUskyyy/p/6105352.html
Copyright © 2011-2022 走看看