• [蓝桥杯] 算法训练 接水问题


      算法训练 接水问题  

    时间限制:1.0s   内存限制:64.0MB

          

    问题描述

      学校里有一个水房,水房里一共装有m 个龙头可供同学们打开水,每个龙头每秒钟的 供水量相等,均为1。 现在有n 名同学准备接水,他们的初始接水顺序已经确定。将这些同学按接水顺序从1 到n 编号,i 号同学的接水量为wi。接水开始时,1 到m 号同学各占一个水龙头,并同时打 开水龙头接水。当其中某名同学j 完成其接水量要求wj 后,下一名排队等候接水的同学k 马上接替j 同学的位置开始接水。这个换人的过程是瞬间完成的,且没有任何水的浪费。即 j 同学第x 秒结束时完成接水,则k 同学第x+1 秒立刻开始接水。若当前接水人数n’不足m, 则只有n’个龙头供水,其它m−n’个龙头关闭。 现在给出n 名同学的接水量,按照上述接水规则,问所有同学都接完水需要多少秒。

    输入格式

      第1 行2 个整数n 和m,用一个空格隔开,分别表示接水人数和龙头个数。 第2 行n 个整数w1、w2、……、wn,每两个整数之间用一个空格隔开,wi 表示i 号同 学的接水量。

    输出格式

      输出只有一行,1 个整数,表示接水所需的总时间。

    样例输入

    5 3
    4 4 1 2 1

    样例输出

    4

    样例输入

    8 4
    23 71 87 32 70 93 80 76

    样例输出

    163

    输入输出样例 1 说明

      第1 秒,3 人接水。第1 秒结束时,1、2、3 号同学每人的已接水量为1,3 号同学接完
      水,4 号同学接替3 号同学开始接水。
      第2 秒,3 人接水。第2 秒结束时,1、2 号同学每人的已接水量为2,4 号同学的已接
      水量为1。
      第3 秒,3 人接水。第3 秒结束时,1、2 号同学每人的已接水量为3,4 号同学的已接
      水量为2。4 号同学接完水,5 号同学接替4 号同学开始接水。
      第4 秒,3 人接水。第4 秒结束时,1、2 号同学每人的已接水量为4,5 号同学的已接
      水量为1。1、2、5 号同学接完水,即所有人完成接水。
      总接水时间为4 秒。

    数据规模和约定

      1 ≤ n ≤ 10000,1 ≤m≤ 100 且m≤ n;
      1 ≤ wi ≤ 100。

    题意比较简单清晰

    设立一个长度为水管数的数组 从前往后赛数 

    然后找到这一组水管中最小值 全都减掉 最小值减为零了 继续往后赛数;

    答案加最小值 重复

    #include <iostream>
    #include <algorithm>
    using namespace std;
    int a[10010],b[10010],n,m;
    int main()
    {
    	int flag=0,ans=0;
    	cin>>n>>m;
    	for(int i=0;i<n;i++)
    		scanf("%d",&b[i]);
    	for(int i=0;i<m;i++)
    		a[i]=b[flag++];
    	while(1)
    	{
    		int tf=0;
    		for(int i=0;i<m;i++)
    			if(a[i]!=0)//判断退出条件:所有水管都为零且要接水的人已经轮完
    				tf=1;
    		if(!tf)
    			break;
    		sort(a,a+m);
    		tf=0;
    		for(tf;a[tf]==0;tf++);//插非零最小数
    		int tmp=a[tf];
    		for(int i=0;i<m;i++)
    		{
    			if(a[i]!=0)
    				a[i]-=tmp;//减最小数
    			if(a[i]==0&&flag<n)
    				a[i]=b[flag++];//往后填同学
    		}
    		ans+=tmp;
    	}
    	cout<<ans<<endl;
    	return 0;
    }
  • 相关阅读:
    HTML常用标签(自用,可能不严谨,勿怪)
    Nginx负载均衡和反向代理设置
    Django的列表反序
    Python装饰器通用样式
    WCF、Web API、WCF REST、Web Service的区别
    C++11 标准新特性: 右值引用与转移语义
    在windows下vs使用pthread
    部分浏览器记住密码后可能会带来的问题
    SQL Server、 My SQL、PG Sql、Oracle、 Access 不同数据库sql差异
    sql中select语句的逻辑执行顺序
  • 原文地址:https://www.cnblogs.com/zeolim/p/12270767.html
Copyright © 2020-2023  润新知