Codeforces Round 905 (Div. 2) - B. Raspberries - 思维/取模

B. Raspberries

注意到k只能是2,3,4,5

特判

如果存在一个数ai,满足ai % k ==0。那么操作数为0

(1) K=2,3,5时

因为2,3,5都是素数,所以要想使得a1~an的积能被k整除:a数组中一定有一个数ai,满足ai % k == 0。所以要想满足条件,最小值为 min( k - ai % k )

(2)K=4时

注意到4 = 2 * 2;所以要想使得a1~an的积能被k整除:操作的数量最大只能是2。

在满足特判的情况下,我们统计a数组中偶数的个数cnt_even。

1、如果cnt_even>2,那么一定存在两个数ai和aj,他们的公因子中都含有2。那么乘积的因子中一定含有4。此时输出为0。

2、如果cnt_even == 1,那么此时a数组中只含有一个偶数。那么我们只需要随便把一个奇数加1,即可满足a数组中的两个数因子都含有2。此时输出为1。

3、如果cnt_even==0,那么此时a数组中全部是奇数。此时通过情况(1)中得到的ans结果要么是1,要么是3。输出min(ans , 2)即可。

因为ans如果是3的情况下,比如1 , 1 , 1

那么我们任选两个奇数加一,即可得到4。操作的次数是2。

cpp 复制代码
#include <math.h>
#include <stdio.h>
#include <algorithm>
#include <cstring>
#include <iostream>
using namespace std;
const int N = 2e5 + 10;
#define de(x) cout << x << " ";
#define sf(x) scanf("%d", &x);
#define Pu puts("");
#define ll long long
int n, m, ans;
int a[N];
int k;
int main() {
    int T;
    cin >> T;
    while (T--) {
        cin >> n >> k;
        int x;  // 输入
        ans = 1e9;
        int cnt_even = 0;  // 4对应的判断
        bool is_mod = false;
        for (int i = 1; i <= n; i++) {
            sf(x);
            if (x % k == 0)
                is_mod = true;
            ans = min(ans, k - x % k);  // 2,3,5对应的判断
            if (x % 2 == 0)
                cnt_even++;
        }
        if (is_mod == true) {
            printf("0\n");
            continue;
        }
        if (k == 4) {
            // 通过取模得到的ans要么是1,要么3,要么是2
            if (cnt_even > 1)  // 如果ans是2,说明全是偶数
                printf("0\n");
            else if (cnt_even == 1)  // 此时只有一个奇数
                printf("1\n");
            else  // 如果是1或者3,说明全是偶数,此时的ans最大是2
                cout << min(2, ans) << endl;
        } else {
            printf("%d\n", ans);
        }
    }
    return 0;
}
相关推荐
Xの哲學2 分钟前
Linux设备驱动模型深度解剖: 从设计哲学到实战演练
linux·服务器·网络·算法·边缘计算
明洞日记17 分钟前
【CUDA手册002】CUDA 基础执行模型:写出第一个正确的 Kernel
c++·图像处理·算法·ai·图形渲染·gpu·cuda
企业对冲系统官1 小时前
基差风险管理系统集成说明与接口规范
大数据·运维·python·算法·区块链·github
程序员-King.1 小时前
day134—快慢指针—环形链表(LeetCode-141)
算法·leetcode·链表·快慢指针
Swift社区1 小时前
LeetCode 376 摆动序列
算法·leetcode·职场和发展
高洁011 小时前
AIGC技术与进展(1)
深度学习·算法·机器学习·transformer·知识图谱
未来之窗软件服务1 小时前
计算机等级考试——二叉树考点和坑——东方仙盟
算法·二叉树·计算机软考·仙盟创梦ide·东方仙盟
张张努力变强1 小时前
C++类和对象(一):inline函数、nullptr、类的定义深度解析
开发语言·前端·jvm·数据结构·c++·算法
且去填词2 小时前
深入理解 GMP 模型:Go 高并发的基石
开发语言·后端·学习·算法·面试·golang·go
Hcoco_me2 小时前
大模型面试题76:强化学习中on-policy和off-policy的区别是什么?
人工智能·深度学习·算法·transformer·vllm