动态规划-百度-罪犯转移
2016-04-13 12:54
267 查看
C市现在要转移一批罪犯到D市,C市有n名罪犯,按照入狱时间有顺序,另外每个罪犯有一个罪行值,值越大罪越重。现在为了方便管理,市长决定转移入狱时间连续的c名犯人,同时要求转移犯人的罪行值之和不超过t,问有多少种选择的方式?
输入描述:第一行数据三个整数:n,t,c(1≤n≤2e5,0≤t≤1e9,1≤c≤n),第二行按入狱时间给出每个犯人的罪行值ai(0≤ai≤1e9)。
输入例子:
3 100 2
1 2 3
输出:
2
思路:利用滑动窗口的性质来做建立一个c大小的滑动窗口,从开始一直滑到最后,每次进行和t判断,如果符合就加一,不符合就往后面滑动。
代码如下:
输入描述:第一行数据三个整数:n,t,c(1≤n≤2e5,0≤t≤1e9,1≤c≤n),第二行按入狱时间给出每个犯人的罪行值ai(0≤ai≤1e9)。
输入例子:
3 100 2
1 2 3
输出:
2
思路:利用滑动窗口的性质来做建立一个c大小的滑动窗口,从开始一直滑到最后,每次进行和t判断,如果符合就加一,不符合就往后面滑动。
代码如下:
public static void main(String args[]){ Scanner in=new Scanner(System.in); while(in.hasNext()){ int n = in.nextInt(); int t = in.nextInt(); int c = in.nextInt(); int[] a = new int ; for(int i = 0;i<n;i++){ a[i] = in.nextInt(); } int count = 0; int tempt = 0; //建立起始滑动窗口 for(int i = 0;i<c;i++){ tempt += a[i]; } if(tempt<=t) count++; for(int i = c;i<a.length;i++){ tempt = tempt+a[i]-a[i-c]; if(tempt<=t) count++; } System.out.println(count); } }
相关文章推荐
- 【BZOJ3514】Codechef MARCH14 GERALD07加强版
- 如何去除Linux文件的^M字符
- spark入门及其环境搭建
- android的Bundle
- 【转】数据库常见面试题
- 希尔排序
- android学习12——重载SurfaceView一些方法的执行顺序
- Linux终端telnet连接xxx邮箱server通过命令行实现mail发送
- Ubuntu Server设置语言为英文
- 【LeetCode-27】Remove Element
- hive数据仓库入门及其环境搭建
- Xcode 创建c++项目
- 希尔排序
- Xib的使用与File'Owner总结
- HUST 1010 The Minimum Length
- 在2016(第八届)企业级数据中心建设论坛的演讲
- 在2016(第八届)企业级数据中心建设论坛的演讲
- 总结下自己的做的小视频吧,挺有趣发现也挺幼稚,哈哈
- 企业信息调查
- 将openstack 默认的GRE网络改为VXLAN网络