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;
    }
}
相关推荐
2601_9491465312 小时前
C语言语音通知接口接入教程:如何使用C语言直接调用语音预警API
c语言·开发语言
你撅嘴真丑12 小时前
第九章-数字三角形
算法
在路上看风景12 小时前
19. 成员初始化列表和初始化对象
c++
uesowys12 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
zmzb010312 小时前
C++课后习题训练记录Day98
开发语言·c++
ValhallaCoder12 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮12 小时前
AI 视觉连载1:像素
算法
念风零壹13 小时前
C++ 内存避坑指南:如何用移动语义和智能指针解决“深拷贝”与“内存泄漏”
c++
智驱力人工智能13 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
孞㐑¥14 小时前
算法——BFS
开发语言·c++·经验分享·笔记·算法