1044,1064

1044


/*
火星人是以 13 进制计数的:

    地球人的 0 被火星人称为 tret。
    地球人数字 1 到 12 的火星文分别为:jan, feb, mar, apr, may, jun, jly, aug, sep, oct, nov, dec。
    火星人将进位以后的 12 个高位数字分别称为:tam, hel, maa, huh, tou, kes, hei, elo, syy, lok, mer, jou。

例如地球人的数字 29 翻译成火星文就是 hel mar;而火星文 elo nov 对应地球数字 115。为了方便交流,请你编写程序实现地球和火星数字之间的互译。
输入格式:

输入第一行给出一个正整数 N(<100),随后 N 行,每行给出一个 [0, 169) 区间内的数字 —— 或者是地球文,或者是火星文。
输出格式:

对应输入的每一行,在一行中输出翻译后的另一种语言的数字。
输入样例:

4
29
5
elo nov
tam

输出样例:

hel mar
may
115
13
*/
#include <bits/stdc++.h>
using namespace std;
int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    //数字到火星文低位的映射
    array<string, 13> low = {"tret", "jan", "feb", "mar", "apr", "may", "jun",
                             "jly",  "aug", "sep", "oct", "nov", "dec"};
    //数字到火星文高位的映射
    array<string, 13> high = {"tret", "tam", "hel", "maa", "huh", "tou", "kes",
                              "hei",  "elo", "syy", "lok", "mer", "jou"};
    unordered_map<string, int> temp;  //火星文到数字的映射
    for (int i = 0; i < 13; ++i) {
        temp[low[i]] = i;
        temp[high[i]] = i * 13;
    }
    int n;
    cin >> n;
    cin.get();  //吸收空格字符
    string digit = "";
    while (n--) {
        getline(cin, digit);
        if (isdigit(digit[0])) {  //如果是数字
            int k = stoi(digit);
            if (k / 13 != 0)  //高位不为0,输出高位
                cout << high[k / 13];
            if (k / 13 != 0 && k % 13 != 0)  //高位低位均不为0,输出空格
                cout << ' ';
            //高位为0或者高位不为0但低位为0时,输出低位
            if (k / 13 == 0 || k % 13 != 0)
                cout << low[k % 13];
            cout << '\n';  //换行
        } else {  //是火星文
            int k = 0;
            stringstream stream(digit);//复制digit到stringstream stream
            while (stream >> digit)  //按空格键分割字符串
                k += temp[digit];
            cout << k << '\n';
        }
    }
    return 0;
}

总结:

1.unordered_map常用于不同数据类型之间的映射,相当于一个普通vector使

例如:

unordered_map<String,int> a={{"hello",1},{"nihao",2}};
//之前也介绍过,之前做过的1014 建立了ABCDEFG七个字符到星期的映射
unordered_map<char, string> week = {{'A', "MON"}, {'B', "TUE"}, {'C', "WED"}, {'D', "THU"},
                                        {'E', "FRI"}, {'F', "SAT"}, {'G', "SUN"}};

2.stringstream的使用:

stringstream stream;
stream<<t;//向流中传值
out_type result;//这里存储转换结果
stream>>result;//向result中写入值
 stringstream ss(line);//复制line到stringstream ss 

有一个技巧干掉输入的空格:本题中使用了

  while (stream >> digit)  //按空格键分割字符串

解释一下:汤神经常写的notes,俺也来:stream >> digit当stream出现空格字符传给digit时,此while循环懂吧。。

给个参考链接吧:https://www.cnblogs.com/hujunzheng/p/5042068.html

1064

/*
如果两个整数各位数字的和是一样的,则被称为是“朋友数”,而那个公共的和就是它们的“朋友证号”。
例如 123 和 51 就是朋友数,因为 1+2+3 = 5+1 = 6,而 6 就是它们的朋友证号。给定一些整数,要求你统计一下它们中有多少个不同的朋友证号。
输入格式:

输入第一行给出正整数 N。随后一行给出 N 个正整数,数字间以空格分隔。
输出格式:

首先第一行输出给定数字中不同的朋友证号的个数;随后一行按递增顺序输出这些朋友证号,数字间隔一个空格,且行末不得有多余空格。
输入样例:

8
123 899 51 998 27 33 36 12

输出样例:

4
3 6 9 26
*/
#include <bits/stdc++.h>
using namespace std;
using gg = long long;
int main() {
    ios::sync_with_stdio(false);
    gg n;
    set<gg> s;
    cin >> n;
    while (n--) {
        gg sum = 0, a;
        cin >> a;
        //数字的各位求和 
        do {
            sum += a % 10;
            a /= 10;
        } while (a != 0);
        
        s.insert(sum);
    }
    cout << s.size() << '\n';
    for (auto i = s.begin(); i != s.end(); ++i) {
        cout << (i == s.begin() ? "" : " ") << *i;
    }
    return 0;
}
/*
如果两个整数各位数字的和是一样的,则被称为是“朋友数”,而那个公共的和就是它们的“朋友证号”。
例如 123 和 51 就是朋友数,因为 1+2+3 = 5+1 = 6,而 6 就是它们的朋友证号。给定一些整数,要求你统计一下它们中有多少个不同的朋友证号。
输入格式:

输入第一行给出正整数 N。随后一行给出 N 个正整数,数字间以空格分隔。
输出格式:

首先第一行输出给定数字中不同的朋友证号的个数;随后一行按递增顺序输出这些朋友证号,数字间隔一个空格,且行末不得有多余空格。
输入样例:

8
123 899 51 998 27 33 36 12

输出样例:

4
3 6 9 26
*/
#include <bits/stdc++.h>
using namespace std;
using gg = long long;
int main() {
    ios::sync_with_stdio(false);
    gg n;
    set<gg> s;
    cin >> n;
    while (n--) {
        gg sum = 0, a;
        cin >> a;
        //数字的各位求和 
        do {
            sum += a % 10;
            a /= 10;
        } while (a != 0);
        
        s.insert(sum);
    }
    cout << s.size() << '\n';
    for (auto i = s.begin(); i != s.end(); ++i) {
        cout << (i == s.begin() ? "" : " ") << *i;
    }
    return 0;
}

这题主要就是set的使用:

1.关于set,必须说明的是set关联式容器。set作为一个容器也是用来存储同一数据类型的数据类型,并且能从一个数据集合中取出数据,在set中每个元素的值都唯一,而且系统能根据元素的值自动进行排序。应该注意的是set中数元素的值不能直接被改变。

2.set中常用的方法

begin()    ,返回set容器的第一个元素
end()      ,返回set容器的最后一个元素
clear()    ,删除set容器中的所有的元素
empty()    ,判断set容器是否为空
max_size()   ,返回set容器可能包含的元素最大个数
size()      ,返回当前set容器中的元素个数
rbegin     ,返回的值和end()相同
rend()     ,返回的值和rbegin()相同

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容