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;

算法一:贪心

代码
 #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;
} 
 
 

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-17 00:14:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-17 00:14:01       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-17 00:14:01       87 阅读
  4. Python语言-面向对象

    2023-12-17 00:14:01       96 阅读

热门阅读

  1. C 语言教程:数据类型和格式说明符

    2023-12-17 00:14:01       60 阅读
  2. python多线程介绍

    2023-12-17 00:14:01       67 阅读
  3. Hostlink通讯协议解析【串行 C-Mode和Fins】

    2023-12-17 00:14:01       96 阅读
  4. skynet笔记

    2023-12-17 00:14:01       43 阅读
  5. Vue的相关指令

    2023-12-17 00:14:01       57 阅读
  6. 点评项目——UV统计

    2023-12-17 00:14:01       59 阅读
  7. Linux 系统中包管理工具

    2023-12-17 00:14:01       52 阅读
  8. linux 常用脚本搜集(nginx) —— 筑梦之路

    2023-12-17 00:14:01       59 阅读
  9. c++中的new与delete

    2023-12-17 00:14:01       70 阅读