题解 | #魔法人偶的十进制校准#

魔法人偶的十进制校准

https://ac.nowcoder.com/acm/problem/312885

赛时为数不多做出来的数学题

观察样例发现很难构造,因为第 位要放一个数字,不可能真像 那样这么好枚举,但是第二个样例提醒了我们,如果是无限循环小数,就不需要管位置。

考公的时候学过百化分,注意到 ,那么就分为以下几种情况

  • 数字为0:如果要求放小数点后第一位,可以直接是,如果不是,可以 直接是

  • 数字为9:也就是需要,但并没有这样的数字,但算多几个百化分就知道,,也就是偶数位一定是9,如果 是偶数,就直接输出这个,那么是奇数的话,就前移一位,也就是

  • 数字在 之间,直接输出,但注意,由于 有一个约数,事实上可以直接输出

代码如下:

#include <bits/stdc++.h>
#define rep(i,a,b) for(int i=a;i<=b;i++)
using namespace std;
const int N=2e5+7;
const int M=1e9+7;
typedef long long ll;
typedef vector<int> vt;


void solve(){
    int a,b;
    cin>>a>>b;
    if(b!=9 && b!=0){
        if(b==3)cout<<"1 3\n";
        else if(b==6)cout<<"2 3\n";
        else cout<<b<<" 9\n";
    }
    else if(b==0){
        if(a==1)cout<<"1 20\n"; //如果第一位就要0,0.05就可以
        else cout<<"1 10\n";//否则可以构造0.100000
    }
    else if(b==9){
        if(a%2==0)cout<<"1 11\n";
        else cout<<"10 11\n";
    }
    return;
}
int main(){
    ios::sync_with_stdio(false),cin.tie(0);
    int T=1;
    cin>>T;
    while(T--)solve();
    return 0;
}

全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务