Before an Exam

题目名字 Before an Exam

题目链接

题意

给定天数和目标,然后接下来输入每天的最少时间和最多时间,先判断在每天的范围内能否完成目标,如果不能输出no,如果能就输出每天在给定范围内完成的时间

思路

  1. 先用maxsum来将每天的最大时间相加,minsum将每天最少的时间相加,判断maxsum是否小于sumtime且minsum是否大于sumtime,如果是输出no,不是就输出yes然后继续判断
  2. 先用sumtime减掉minsum,判断剩余的sumtime是否小于范围的差值,如果大于,就使这天的学习最小量变为最大学习量,为了后面的输出,继续判断,直到sumtime小于两个之间的差值,然后使这天的mintime加等于这个sumtime
    3.最后循环输出d天的mintime;

算法一:贪心

代码
cpp 复制代码
 #include <bits/stdc++.h> 
using namespace std; 
int main() { 
    int d,sumtime; 
    cin>>d>>sumtime; 
    int mintime[d], maxtime[d]; 
    int maxsum=0,minsum=0,temp=0; 
    for (int i=0;i<d;i++){ 
        scanf("%d %d",&mintime[i],&maxtime[i]);  
        maxsum+=maxtime[i]; 
        minsum+=mintime[i]; 
    } 
    if(maxsum<sumtime||minsum>sumtime){ 
        cout<<"NO"<<endl; 
        return 0; 
    } 
    else{ 
        cout<<"YES"<<endl; 
        sumtime-=minsum; 
        int i=0;
        while(sumtime){
            if(sumtime>maxtime[i]-mintime[i]){ 
                sumtime-=maxtime[i]-mintime[i]; 
                mintime[i]=maxtime[i]; 
            } 
            else{ 
                mintime[i]+=sumtime;
                sumtime=0;
            } 
            i++;
        }
        for (int i=0;i<d;i++){
            cout<<mintime[i]<<" ";
        } 
    }     
    return 0;
} 
 
 
相关推荐
白羊by7 小时前
YOLOv1~v11 全版本核心演进总览
深度学习·算法·yolo
墨尘笔尖9 小时前
最大最小值降采样算法的优化
c++·算法
white-persist11 小时前
【vulhub shiro 漏洞复现】vulhub shiro CVE-2016-4437 Shiro反序列化漏洞复现详细分析解释
运维·服务器·网络·python·算法·安全·web安全
FL162386312911 小时前
基于C#winform部署软前景分割DAViD算法的onnx模型实现前景分割
开发语言·算法·c#
baizhigangqw12 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶
算法·启发式算法·web app
C雨后彩虹12 小时前
最多等和不相交连续子序列
java·数据结构·算法·华为·面试
cpp_250113 小时前
P2347 [NOIP 1996 提高组] 砝码称重
数据结构·c++·算法·题解·洛谷·noip·背包dp
Hugh-Yu-13012313 小时前
二元一次方程组求解器c++代码
开发语言·c++·算法
编程大师哥14 小时前
C++类和对象
开发语言·c++·算法
加农炮手Jinx14 小时前
LeetCode 146. LRU Cache 题解
算法·leetcode·力扣