Codeforces Round 955 (Div. 2) A~E

A.Soccer(思维)

题意:

迪马喜欢看足球比赛。在这样一场比赛中,记分牌上的比分表示为xxx:yyy,其中xxx是第一队的进球数,yyy是第二队的进球数。在任何时候,只有一支球队可以进球,因此比分xxx:yyy可以变为(x+1)(x+1)(x+1):yyy,或者xxx:(y+1)(y+1)(y+1)

在观看足球比赛时,迪马被一些非常重要的事情分散了注意力,过了一段时间,他又重新开始观看比赛。迪马记得他走神前的比分和他回来后的比分。鉴于这两个比分,他想知道以下问题。有没有可能在迪马没有看比赛的时候,两队的比分从来没有相同过?

可以肯定的是,在迪马记得的两个时间点上,两队的比分都不相等。不过,也有可能在他不在的时候,比分并没有发生变化。

请帮助迪马回答问题!

分析:

我们将之前的比分表示为[x1,y1][x_1,y_1][x1,y1],之后的比分表示为[x2,y2][x_2,y_2][x2,y2]。二者不相交则不可能出现相同的分数。

代码:

#include<bits/stdc++.h>

using namespace std;

void solve() {
   
   
    int x1, y1, x2, y2;
    cin >> x1 >> y1 >> x2 >> y2;
    if (x1 < y1) {
   
   
        if (x2 >= y2) {
   
   
            cout << "NO" << endl;
        } else {
   
   
            cout << "YES" << endl;
        }
    } else if (x1 > y1) {
   
   
        if (x2 <= y2) {
   
   
            cout << "NO" << endl;
        } else {
   
   
            cout << "YES" << endl;
        }
    } else {
   
   
        cout << "YES" << endl;
    }
}

int main() {
   
   
    int t;
    cin >> t;
    while (t--)
        solve();
    return 0;
}

B.Collatz Conjecture(思维、数学)

题意:

最近,一年级学生马克西姆学习了科拉兹猜想,但他在讲课时没有太注意,所以他认为猜想中提到了以下过程:

有一个变量xxx和一个常数yyy。下面的操作进行了kkk次:

  • xxx增加111,然后
  • 当数字xxx能被yyy整除时,再除以yyy

请注意,这两个操作都是在一次操作中依次进行的。

例如,如果数字x=16x=16x=16y=3y=3y=3k=2k=2k=2,那么经过一次运算后,xxx就变成了171717,而经过另一次运算后,xxx就变成了222,因为加一后,x=18x=18x=18就能被333整除两次。

鉴于初始值为xxxyyykkk,马克西姆想知道xxx的最终值是多少。

分析:

直接模拟会超时。考虑如果xxx等于111,可以直接跳出循环,用数学方法解决,因为这时xxx就一直会在[1,y][1,y][1,y]之间。

代码:

#include<bits/stdc++.h>

using namespace std;

void solve() {
   
   
    int x, y, k;
    cin >> x >> y >> k;
    while (k != 0 && x != 1) {
   
   
        int t = min(k, y - x % y);
        x += t;
        k -= t;
        while (x % y == 0) {
   
   
            x /= y;
        }
    }
    k %= (y - 1);
    x = x + k;
    cout << x 
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值