• cf 1169 C Increasing by Modulo


    cf 1169 C. Increasing by Modulo

    题意

    给你一个n个数字的序列,有一个操作是选其中的一些数字来+1,最后使得序列每一个数取模m后是一个非严格单调递增的序列,问至少需要多少次操作?

    题解

    二分答案+一点点思维(代码易懂

    #include <cstdio>
    
    int a[300010], b[300010];
    int main() {
        int n, m, ans = 0;
        scanf("%d %d", &n, &m);
        for(int i = 0; i < n; i++) scanf("%d", &a[i]);
        int l = 0, r = m;
        while(l < r) {
            int mid = (l + r) / 2, flag = 0;
            b[0] = a[0];
            if(a[0] + mid >= m) b[0] = 0;
            for(int i = 1; i < n; i++) {
                if(a[i] >= b[i-1]) {
                    b[i] = a[i];
                    if(a[i] + mid >= m && (a[i] + mid) % m >= b[i-1]) b[i] = b[i-1];
                }
                else if(a[i] + mid >= b[i-1]) b[i] = b[i-1];
                else {
                    flag = 1;
                    break;
                }
            }
            if(flag) l = mid + 1;
            else ans = mid, r = mid;
        }
        printf("%d
    ", ans);
        return 0;
    }
    
    
  • 相关阅读:
    HDU 1078 FatMouse and Cheese(DP)
    HDU 1160 FatMouse's Speed(DP)
    作业DAY019
    作业DAY018
    作业DAY017
    作业DAY016
    作业DAY015
    作业DAY014
    作业DAY013
    作业DAY012
  • 原文地址:https://www.cnblogs.com/fanshhh/p/11380589.html
Copyright © 2020-2023  润新知