MT2001 幸运的3

已经变成数学的形状了传送门

题目描述

给出n个数,可以两两配对(首位相连,比如13 ,78 变成1378 或7813),每个数只能使用一次,最多能有几个三的倍数,没匹配的数不考虑

解题思路

直接讲数学规律:一个数对3取模,要么模为1,要么模为2,要么是0;

两个数配对之后,如果是3的倍数,要满足这样的数学规律:它们的余数之和想加为3的倍数,或者是0;

这个数学规律还是比较好发现的,我自己在模拟的时候,找到了 13 和 23,随后发现13对3取模是1,23对3取模是2,相加刚好是3,所以就慢慢推导出了这个规律

ac✅️代码

复制代码
#include<bits/stdc++.h> 

using namespace std;
int cnt1,cnt2,cnt3;



int main( )
{
    int n;cin>>n;
    for(int i = 0 ; i < n ; i++) 
    {
        int x;cin>>x;
        int rem = x % 3;
        if(rem == 1) cnt1 ++;
        else if(rem == 2) cnt2++;
        else cnt3 ++;
    }

    int ans = 0;

    if(cnt1 != 0 && cnt2 != 0) ans += min(cnt1,cnt2);
    ans += cnt3/2;

    cout<<ans<<endl;


    // cout<<cnt / 2 <<endl;
    

    return 0;
}
相关推荐
Sunsets_Red2 天前
模意义下及同余的公式整理
c语言·c++·数学·算法·c#·数论·信息学竞赛
Tisfy3 天前
LeetCode 1622.奇妙序列:懒更新
数学·算法·leetcode·题解·设计
闻缺陷则喜何志丹4 天前
【巴什博弈 线性筛】P8901 [USACO22DEC] Circular Barn S|普及+
c++·数学·洛谷·巴什博弈·线型筛
Tisfy4 天前
LeetCode 1415.长度为 n 的开心字符串中字典序第 k 小的字符串:DFS构造 / 数学O(n)
数学·算法·leetcode·深度优先·字符串·dfs·模拟
切糕师学AI5 天前
什么是幂等(Idempotence)?
数学·设计原则·幂等·幂等性
niuniudengdeng6 天前
六面独立转动魔方还原机器人设计与实现
数学·算法·机器人
Luhui Dev21 天前
Google DeepMind Aletheia:完全自主研究的数学 Agent 解读
人工智能·数学
王老师青少年编程22 天前
csp信奥赛C++之反素数
数据结构·c++·数学·算法·csp·信奥赛·反素数