結果

問題 No.1464 Number Conversion
ユーザー tabae326tabae326
提出日時 2021-04-02 21:54:28
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 2 ms / 2,000 ms
コード長 1,095 bytes
コンパイル時間 1,960 ms
コンパイル使用メモリ 194,804 KB
最終ジャッジ日時 2025-01-20 09:06:35
ジャッジサーバーID
(参考情報)
judge2 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 29
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;
using ll = long long;
#define rep(i, srt, end) for (long long i = (srt); i < (long long)(end); i++)

/*
オーバーフローには気を付けよう!
Inputs:
    string s : string representing a decimal number, such as 123.4, 0.123, 123.
    logn long shift_size : shift size, formally, this function return s * 10 ^ shift_size.
Output:
    Return s * 10 ^ shift_size as long long.
*/
long long str2dec(string s, long long shift_size) {
    auto pos = s.find('.');
    if(pos == string::npos) return atoll(s.c_str()) * pow(10LL, shift_size); // If s is an integer
    long long res = atoll(s.substr(0, pos).c_str()) * pow(10LL, shift_size); 
    res += atoll(s.substr(pos+1, s.size()-pos-1).c_str()) * pow(10LL, shift_size - (s.size()-pos-1));
    return res;
}


void solve() {
    string s;
    cin >> s;
    ll d = str2dec(s, 8);
    ll a = d;
    ll b = 100000000;
    ll g = gcd(a, b);
    a /= g; b /= g;
    cout << a << "/" << b << endl;
}

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    solve();
    return 0;
}
0