这是一道if−elseif-elseif−else语句的基础题目,由于数据量很大达到了1010510^{10^{5}}10105,换成101010进制会有10510^{5}105位,而我们现阶段的数据类型最多也只能存下几十位大的数,所以这题我们得用别的方法存下来,而什么数据类型能存下10510^5105的数据呢,显然是字符串类型(String),那么我们就可以使用s1,s2s_1,s_2s1,s2存下a1,a2a_1,a_2a1,a2,
我们发现a1a_1a1是多少并不重要,我们只关系其奇偶性,那么我们只需要判断其最后一位的奇偶性即可,那么我们可以使用字符串的函数s1.back()s_1.back()s1.back()来获取s1s_1s1的最后一个位置上的字符,但是我们此时取出来的只是一个字符,并不是一个数,对于一个在’000‘−-−999’之间的字符ccc,我们使用ccc-'000’即可获取到其对应的数值,最后再根据a2a_2a2把a2a_2a2分成三种情况讨论即可。
不懂的可以看代码注释:
inline void solve(){string s1,s2;//使用字符串读入a1,a2cin>>s1>>s2;int a=s1.back()-'0';//获取a1最后一位if(s2[0]=='5'){int f=1;//标记后面是否全是0for(int i=1;i//判断后面是否全是0if(s2[i]!='0'){f=0;break;}}if(f){//后面全是0,那么当前a2=5if(a%2){//当a1为奇数时进位所以多了cout<<"Happy birthday to MFGG"<//当a1为偶数时去掉小数部分所以少了cout<<"Happy birthday to YXGG"<//后面不全是0,那么当前a2>5,因此会进位,所以多了cout<<"Happy birthday to MFGG"<'5'){//a2>5,因此会进位,所以多了cout<<"Happy birthday to MFGG"<//因为不含有前导0,所以a2=0,此时不进不舍,所以不变cout<<"PLMM"<//0