题解 CF614A 【Link/Cut Tree】

本题难度不大,就像第一篇题解,就是暴力算,但这个数据类型是个坑,还真只能用long double。

unsigned long long

long long

double

unsigned int

都会WA

害得我就这水题WA了几次

那么,代码:

#include <iostream>
using namespace std;

int main()
{
    long double l, r, k, x, cnt = 0;
    cin >> l >> r >> k;
    if(k == 1)//特判
    {
        cout << (l == 1 ? 1 : -1) << endl;
        exit(0);
    }
    x = 1;//注意初始值为1
    while(x < l)//先乘到范围内
    {
        x *= k;
    }
    while(x >= l && x <= r)
    {
        cout << (long long)x << " ";//强转long long,long double可是科学计数法
        cnt++;
        x *= k;
    }
    if(cnt == 0)
    {
        cout << "-1\n";
    }
    else
    {
        cout << endl;//换行好习惯
    }
    return 0;
}

End.

posted @ 2020-10-29 17:38  HappyBobb  阅读(5)  评论(0)    收藏  举报  来源