博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
cf 1169 C Increasing by Modulo
阅读量:4332 次
发布时间:2019-06-06

本文共 887 字,大约阅读时间需要 2 分钟。

cf 1169 C.

题意

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

题解

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

#include 
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\n", ans); return 0;}

转载于:https://www.cnblogs.com/fanshhh/p/11380589.html

你可能感兴趣的文章
Ubuntu菜鸟入门(五)—— 一些编程相关工具
查看>>
valgrind检测linux程序内存泄露
查看>>
Hadoop以及组件介绍
查看>>
1020 Tree Traversals (25)(25 point(s))
查看>>
第一次作业
查看>>
“==”运算符与equals()
查看>>
单工、半双工和全双工的定义
查看>>
Hdu【线段树】基础题.cpp
查看>>
时钟系统
查看>>
BiTree
查看>>
5个基于HTML5的加载动画推荐
查看>>
水平权限漏洞的修复方案
查看>>
静态链接与动态链接的区别
查看>>
Android 关于悬浮窗权限的问题
查看>>
如何使用mysql
查看>>
linux下wc命令详解
查看>>
敏捷开发中软件测试团队的职责和产出是什么?
查看>>
在mvc3中使用ffmpeg对上传视频进行截图和转换格式
查看>>
python的字符串内建函数
查看>>
Spring - DI
查看>>