首页 > 其他 > 详细

Codeforces Round #649 (Div. 2) A. XXXXX

时间:2020-06-14 19:00:56      阅读:58      评论:0      收藏:0      [点我收藏+]

题目链接:https://codeforces.com/contest/1364/problem/A

题意

找出大小为 $n$ 的数组 $a$ 的最长连续子数组,其元素和不被 $x$ 整除。

题解

  • 如果数组的每个元素都被 $x$ 整除,则不存在不被 $x$ 整除的子数组
  • 如果整个数组之和不被 $x$ 整除,答案即为整个数组
  • 如果整个数组之和被 $x$ 整除,删去最短的不被 $x$ 整除的一端子数组

代码

#include <bits/stdc++.h>
using namespace std;

void solve() {
    int n, x; cin >> n >> x;
    int a[n] = {}, sum = 0;
    for (int i = 0; i < n; i++) {
        cin >> a[i];
        a[i] %= x, sum += a[i];
    }
    if (sum == 0)
        cout << -1 << "\n";
    else if (sum % x)
        cout << n << "\n";
    else {
        int l = 0, r = n - 1;
        while (a[l] == 0) ++l;
        while (a[r] == 0) --r;
        cout << max(n - 1 - l, r) << "\n";
    }
}

int main() {
    int t; cin >> t;
    while (t--) solve();
}

 

Codeforces Round #649 (Div. 2) A. XXXXX

原文:https://www.cnblogs.com/Kanoon/p/13125654.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!