C. Raspberries-Codeforces Round 905 (Div. 3)

C. Raspberries

输入n个数,最少给这些数加几次可以让所以数乘积被k整除

题目中给出k的范围2<=k<=5,情况很少,分类讨论。

分析:只有当k=4的时候存在给两个数都+1的情况,其他k都只可以给一个数一直+1直到这个数可以mod k=0;

当k=4时单独考虑:

1.出现a[i]%k=1的数大于等于2,答案可以ans=min(ans,2)

2.出现a[i]%k=2的数大于等于2,答案可以ans=0

3.出现(a[i]%k=1的数量)>=1&&(a[i]%k=2的数量)>=1,答案可以ans=min((int)1,ans)

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<vector>
#define int long long
using namespace std;
const int INF=0x3f3f3f3f;
signed main()
{
    int T;cin>>T;
    while(T--)
    {
        int n,k;cin>>n>>k;
        int a[n+2];
        int ans=INF;
        int cal=1;
        for(int i=1;i<=n;i++)//选取一个数加到可以整除k
        {
            cin>>a[i];cal*=a[i];
            if(a[i]%k==0){
                ans=0;
            }
            int t=a[i]/k+1;
            ans=min(ans,t*k-a[i]);
        }
        if(k==4)
        {
            int cnt1=0,cnt2=0;
            for(int i=1;i<=n;i++)
            {
                switch (a[i]%4)
                {
                case 1:
                    cnt1++;
                    break;
                case 2:
                    cnt2++;
                    break;
                case 3:
                    break;
                default:
                    ans=0;
                    break;
                }
            }
            if(cnt1>=2) ans=min((int)2,ans);
            if(cnt2>=2) ans=0;
            if(cnt1>=1&&cnt2>=1) ans=min((int)1,ans);
        }
        cout<<ans<<endl;
    }
}
相关推荐
为何创造硅基生物5 小时前
C语言 结构体内存对齐规则(通俗易懂版)
c语言·开发语言
吃好睡好便好5 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
仰泳之鹅6 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
jolimark6 小时前
C语言自学攻略:小白入门三步走
c语言·编程入门·学习路线·实践项目·自学攻略
于小猿Sup7 小时前
VMware在Ubuntu22.04驱动Livox Mid360s
linux·c++·嵌入式硬件·自动驾驶
cen__y7 小时前
Linux12(Git01)
linux·运维·服务器·c语言·开发语言·git
社交怪人8 小时前
【算平均分】信息学奥赛一本通C语言解法(题号2071)
c语言·开发语言
x_yeyue8 小时前
三角形数
笔记·算法·数论·组合数学
卢锡荣8 小时前
单芯通吃,盲插标杆 —— 乐得瑞 LDR6020,Type‑C 全场景互联 “智慧芯”
c语言·开发语言·计算机外设
念何架构之路9 小时前
Go语言加密算法
数据结构·算法·哈希算法