算法:C++实现电话号码分身

9 篇文章 0 订阅

题目:首先将电话号码中的每个数字加上8取个位,然后使用对应的大写字母代替 (”ZERO”, “ONE”, “TWO”, “THREE”, “FOUR”, “FIVE”, “SIX”, “SEVEN”, “EIGHT”, “NINE”), 然后随机打乱这些字母,所生成的字符串即为电话号码对应的分身。

思路:通过这些单词我们会发现有些字母只出现在特定的单词中,例如“Z”只出现在“ZERO”这个单词中,那么输入的字符串中包含的“Z”的数目实际上就转换后数字“0”的数目,类似的其他数字我们都可以通过找到专属字符或是通过已确定的数字准确的推算出来,然后我们就可以根据这些个特定的字符来推算对应的数字。

  • 牛客上高人做法:链接
#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
#include <map>

void operMap(std::map<char, int> &index, std::string str, int num) {
    for (int i = 0; i < str.size(); i++) {
        index[str[i]] -= num;
    }
}
int main() {
    using namespace std;
    int t;
    cin >> t;
    while (t--) {
        string str;
        cin >> str;
        map<char, int> index;
        vector<int> arr(10, 0);
        for (int i = 0; i < str.size(); i++) {
            map<char, int>::iterator itor = index.find(str[i]);
            if (itor == index.end()) {
                index[str[i]] = 1;
            }
            else {
                index[str[i]]++;
            }
        }
        arr[2] = index['Z'];
        operMap(index, "ZERO", arr[2]);
        arr[4] = index['W'];
        operMap(index, "TWO", arr[4]);
        arr[6] = index['U'];
        operMap(index, "FOUR", arr[6]);
        arr[8] = index['X'];
        operMap(index, "SIX", arr[8]);
        arr[0] = index['G'];
        operMap(index, "EIGHT", arr[0]);
        arr[3] = index['O'];
        operMap(index, "ONE", arr[3]);
        arr[5] = index['R'];
        operMap(index, "THREE", arr[5]);
        arr[7] = index['F'];
        operMap(index, "FIVE", arr[7]);
        arr[9] = index['V'];
        operMap(index, "SEVEN", arr[9]);
        arr[1] = index['I'];
        operMap(index, "NINE", arr[1]);
        for (int i = 0; i < 10; i++) {
            for (int j = 0; j < arr[i]; j++) {
                cout << i;
            }
        }
        cout << endl;
    }
    return 0;
}

  • 土著民做法(土了自然好理解)
#include<iostream>
#include<vector>
#include<algorithm>
int c2i(char c){
    switch(c){
        case 'Z':return 0;break;
        case 'W':return 2;break;
        case 'U':return 4;break;
        case 'X':return 6;break;
        case 'G':return 8;break;
        case 'H':return 3;break;
        case 'F':return 5;break;
        case 'S':return 7;break;
        case 'O':return 1;break;
        default:return 0;
    }
}
void transfer(std::vector<int>& vec){
    for(int i=0;i<vec.size();++i){
        vec[i]=(vec[i]+2)%10;
    }
}
void countNum(std::vector<int>&vec_c,std::vector<int>&vec_i,int & count){
    while(count>0){
        if(vec_c['Z'-'A']){
            vec_i.push_back(c2i('Z'));
            vec_c['Z'-'A']--;
            vec_c['E'-'A']--;
            vec_c['R'-'A']--;
            vec_c['O'-'A']--;
            count-=4;
        }
        else if(vec_c['W'-'A']){
           vec_i.push_back(c2i('W'));
            vec_c['W'-'A']--;
            vec_c['T'-'A']--;
            vec_c['O'-'A']--;
            count-=3;
        }
        else if(vec_c['U'-'A']){
            vec_i.push_back(c2i('U'));
            vec_c['F'-'A']--;
            vec_c['O'-'A']--;
            vec_c['U'-'A']--;
            vec_c['R'-'A']--;
            count-=4;
        }
        else if(vec_c['X'-'A']){
            vec_i.push_back(c2i('X'));
            vec_c['X'-'A']--;
            vec_c['S'-'A']--;
            vec_c['I'-'A']--;
            count-=3;
        }
        else if(vec_c['G'-'A']){
            vec_i.push_back(c2i('G'));
            vec_c['G'-'A']--;
            vec_c['E'-'A']--;
            vec_c['I'-'A']--;
            vec_c['H'-'A']--;
            vec_c['T'-'A']--;
            count-=5;
        }
        else if(vec_c['H'-'A']){
            vec_i.push_back(c2i('H'));
            vec_c['T'-'A']--;
            vec_c['H'-'A']--;
            vec_c['R'-'A']--;
            vec_c['E'-'A']--;
            vec_c['E'-'A']--;
            count-=5;
        }
        else if(vec_c['F'-'A']){
            vec_i.push_back(c2i('F'));
            vec_c['F'-'A']--;
            vec_c['I'-'A']--;
            vec_c['V'-'A']--;
            vec_c['E'-'A']--;
            count-=4;
        }
        else if(vec_c['S'-'A']){
            vec_i.push_back(c2i('S'));
            vec_c['S'-'A']--;
            vec_c['E'-'A']--;
            vec_c['V'-'A']--;
            vec_c['E'-'A']--;
            vec_c['N'-'A']--;
            count-=5;
        }
        else if(vec_c['O'-'A']){
            vec_i.push_back(c2i('O'));
            vec_c['O'-'A']--;
            vec_c['N'-'A']--;
            vec_c['E'-'A']--;
            count-=3;
        }
    }
}
int main(){
    int num;
    std::cin>>num;
    while(num--){
        std::string temp;
        std::vector<int> vec_c(26,0);
        std::vector<int> vec_i;
        int count=0;
        std::cin>>temp;
        for(int i=0;i<temp.length();++i){
            vec_c[temp[i]-'A']++;
            count++;
        }

        //计数
        countNum(vec_c,vec_i,count);
        transfer(vec_i);
        sort(vec_i.begin(),vec_i.end());
        for(auto c:vec_i){
            std::cout<<c;
        }
        std::cout<<std::endl;
        //输出

    }
    return 0;
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1.设计内容:学生管理系统 使用下面的数据,用C++设计一个简单的学籍管理系统,实现出最基本的功能。 学生基本信息文件(A.TXT)及其内容:A.TXT文件不需要编程录入数据,可用文本编辑工具直接生成: 学号 姓名 性别 宿舍号码 电话号码 01 张成成 男 501 87732111 02 李成华 女 101 87723112 … …. .. … ……….. 学生成绩基本信息文件(B.TXT)及其内容: 学号 课程编号 课程名称 学分 平时成绩 实验成绩 卷面成绩 综合成绩 实得学分 01 A01 大学物理 3 66 78 82 02 B03 高等数学 4 78 -1 90 … …. ………. .. .. … 功能要求及说明: (1)数据录入功能: 对B.TXT进行数据录入,只录入每个学生的学号、课程编号、课程名称、学分、平时成绩、实验成绩、卷面成绩共7个数据. 综合成绩、学分由程序根据条件自动运算。 综合成绩的计算:如果本课程的实验成绩为-1,则表示无实验,综合成绩=平时成绩*30%+卷面成绩*70%; 如果实验成绩不为-1,表示本课程有实验,综合成绩=平时成绩*15%+实验成绩*.15%+卷面成绩*70%。 实得学分的计算: 综合成绩在60以上(含60 ),应得学分=课程学分 综合成绩在60以下 ,应得学分=0 (2)查询功能:分为学生基本情况查询和成绩查询两种 A:学生基本情况查询: 输入一个学号或姓名(可实现选择),查出此生的基本信息并显示输出。 B:成绩查询: 输入一个学号时,查询出此生的所有课程情况,格式如下: 学 号:xx 姓 名:xxxxx 课程编号:xxx 课程名称:xxxxx 综合成绩:xxxx 实得学分: xx 课程编号:xxx 课程名称:xxxxx 综合成绩:xxxx 实得学分: xx 课程编号:xxx 课程名称:xxxxx 综合成绩:xxxx 实得学分: xx … … … … ……… … … 共修:xx科,实得总学分为: xxx (3)删除功能:当在A.TXT中删除一个学生时,自动地在B.TXT中删除此人所有信息。 (4 ) 排序功能:能实现选择按综合成绩或实得学分升序或降序排序并显示数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值