两道例题学map(STL)

例(蓝桥杯):报时助手

问题描述

给定当前的时间,请用英文的读法将它读出来

时间用时h和分m表示,在英文的读法中,读一个时间的方法是:
如果m为0,则将时读出来,然后加上“o’clock”,如3:00读作“three o’clock”
如果m不为0,则将时读出来,然后将分读出来,如5:30读作“five thirty”

时和分的读法使用的是英文数字的读法,其中0~20读作:
0:zero, 1: one, 2:two, 3:three, 4:four, 5:five, 6:six, 7:seven, 8:eight, 9:nine, 10:ten, 11:eleven, 12:twelve, 13:thirteen, 14:fourteen, 15:fifteen, 16:sixteen, 17:seventeen, 18:eighteen, 19:nineteen, 20:twenty
30读作thirty,40读作forty,50读作fifty

对于大于20小于60的数字,首先读整十的数,然后再加上个位数。如31首先读30再加1的读法,读作“thirty one”

按上面的规则21:54读作“twenty one fifty four”,9:07读作“nine seven”,0:15读作“zero fifteen”

输入格式

输入包含两个非负整数h和m,表示时间的时和分。非零的数字前没有前导0。h小于24,m小于60

输出格式

输出时间时刻的英文

样例输入

0 15

样例输出

zero fifteen

代码:

#include<bits/stdc++.h>
#define LL long long
#define fo(i,a,b) for(int i=a;i<b;i++)
using namespace std;
map<int,string> mp;
init(){
    mp[0]="zero";mp[1]="one";mp[2]="two";mp[3]="three";mp[4]="four";mp[5]="five";
    mp[6]="six";mp[7]="seven";mp[8]="eight";mp[9]="nine";mp[10]="ten";mp[11]="eleven";mp[12]="twelve";
    mp[13]="thirteen";mp[14]="fourteen";mp[15]="fifteen";mp[16]="sixteen";
    mp[17]="seventeen";mp[18]="eighteen";mp[19]="nineteen";mp[20]="twenty";
    mp[30]="thirty";mp[40]="forty";mp[50]="fifty";
}
int main(){
    init();
    ios::sync_with_stdio(0);
    int a,b;
    cin>>a>>b;
    if(a<=20)cout<<mp[a]<<" ";
    else cout<<mp[20]<<" "<<mp[a-20]<<" ";
    if(b==0)cout<<"o'clock";
    else if(mp.find(b)!=mp.end())cout<<mp[b];
    else cout<<mp[b/10*10]<<" "<<mp[b%10]; 
    return 0;
}

例题二:

操作序列

代码:

#include<bits/stdc++.h>
#define maxn 300010
#define ll long long
#define pii pair<ll,ll>//可以用上面一行的宏定义 
using namespace std;
map<ll,ll> M;
char st[maxn];
string s; 
int main(){

    int q; 
    cin>>q; 
    getchar();//此时ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);绝对不能加 
    while(q--){
        int t,c,i;
        getline(cin,s);
        stringstream ss(s);//技巧
        for(i=0;i<s.length();i++) if(s[i]==' ') break;
        if(i!=s.length()){//有两个操作数时 
            ss>>t>>c;
//          cout<<t<<","<<c;return 0;输出:140,1 
            int j;
            for(j=-30;j<=30;j++)
                if(M.find(t+j)!=M.end()) break;//一旦找到了就退出         
            if(j==31) M[t]=c;//map增加元素,t为first,c为second(跟肉眼看到的一样)  
        }
        else{
            ss>>t;
            if(t==-1)           
                if(M.empty())cout<<"skipped"<<endl;
                else{
                    cout<<M.begin()->second<<endl;
                    M.erase(M.begin());
                }                            
            else            
                if(M.find(t)==M.end())cout<<0<<endl;
                else cout<<M[t]<<endl;                         
        }
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值