上海市计算机学会竞赛平台2024年11月月赛丙组线段数

题目描述

给定数组 a=[a1,a2,⋯ ,an]a=[a1​,a2​,⋯,an​],Eve 可以执行任意次(可能 00 次)以下操作:

  • 选择 1≤i≤n1≤i≤n,令 ai←ai+1ai←ai+1。

Eve 希望最终数组中任意三个相邻元素之和都是 33 的倍数。

请求出需要达成目标所需的最小操作次数。

输入格式

第一行一个整数 nn。

第二行 nn 个整数 a1,⋯ ,ana1​,⋯,an​。

输出格式

一行一个整数表示答案。

数据范围

对于 30%30% 的数据,3≤n≤53≤n≤5。

对于 60%60% 的数据,3≤n≤10003≤n≤1000。

对于 100%100% 的数据,3≤n≤1053≤n≤105,1≤ai≤1091≤ai​≤109。

样例数据

输入:

3

1 3 5

输出:

0

说明:

1+3+5=9,是 3 的倍数,不需要操作。

输入:

10

2 3 10 25 12 7 10 12 1 46

输出:

3

说明:

对 i=4,7,10 分别操作一次。

详见代码:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int n;
int b[3][3];
int c[3][3];
int ans = 1e9;
int main() 
{
    cin >> n;
    for(int i = 1; i <= n; i++) 
    {
        int a;
        cin >> a;
        b[i % 3][a % 3]++;
    }
    for(int i = 0; i < 3; i++) 
    {
        for(int j = 0; j < 3; j++) 
        {
            for(int k = 0; k < 3; k++) 
            {
                if (j == k) continue;
                if (j > k) 
                {
                    c[i][j] += b[i][k] * (j - k);
                }
                if (j < k) 
                {
                    c[i][j] += b[i][k] * (j + 3 - k);
                }
            }
        }
    }
    for(int i = 0; i < 3; i++)
    {
        for(int j = 0; j < 3; j++) 
        {
            for(int k = 0; k < 3; k++) 
            {
                if ((i + j + k) % 3 == 0) 
                {
                    ans = min(ans, c[0][i] + c[1][j] + c[2][k]);
                }
            }
        }
    }
    cout << ans;
    return 0;
}
相关推荐
单车少年ing9 小时前
一个编码BUG
算法·bug
努力中的编程者9 小时前
哈希表(C语言底层实现)
c语言·数据结构·c++·算法·哈希算法·散列表
CoovallyAIHub9 小时前
ICLR 2026 | MRAD:不拟合直接查表,零样本工业缺陷检测新范式,16 数据集均值最优
深度学习·算法·计算机视觉
摆烂小白敲代码9 小时前
【数据结构与算法】汉诺塔问题(C++)
c语言·开发语言·数据结构·c++·算法·hanoi·汉诺塔问题
Trouvaille ~9 小时前
【递归、搜索与回溯】专题(八):记忆化搜索——从暴力递归到动态规划的桥梁
c++·算法·leetcode·青少年编程·面试·蓝桥杯·动态规划
Pu_Nine_910 小时前
深入理解 ES6 Map 数据结构:从理论到实战应用
前端·javascript·数据结构·es6
飞Link10 小时前
降维打击聚类难题:高斯混合模型 (GMM) 深度解析与实战
人工智能·算法·机器学习·数据挖掘·聚类
沐苏瑶10 小时前
Java数据结构-LinkedList与链表
java·数据结构·链表
dot to one10 小时前
B树系列在数据库中的应用
数据结构·数据库·b树
无尽的罚坐人生10 小时前
hot 100 543. 二叉树的直径
数据结构·算法·leetcode