G - Guards Gym - 101334G 贪心 枚举 题意好难懂啊

2024-02-13 16:58

本文主要是介绍G - Guards Gym - 101334G 贪心 枚举 题意好难懂啊,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!



题意:

给出四种轮班制度

要求:

工作日白天每天有n1个人

休息日白天每天有n2个人

晚上每天有n3个人(不分工作日还休息日)

问:怎么样安排这四种不同轮班制度的人数可以使得总人数最少


题解:

 schedule 1:机动性很高,但是三天才轮班一次

 schedule 2:机动性最低,但是工作日每天都要工作

 schedule 3:机动性高并且工作量也大

 schedule 4:机动性中等,因为白天只能在工作日工作,但是晚上可以在任意时间工作

为保证每天都有相应的人手在工作,所以每一种 schedule 都需要一定量的人来循环工作

 schedule 1  至少需要三个人同时工作才可以覆盖一周

 schedule 2  显然只需要一个人就行了

 schedule 3 需要四个,而不是三个,因为每个人工作周期的尾部有一个休息天

 schedule 4  同理需要五个

题目要求需要人数最少:

那么先选择机动性最高并且工作量大的,这样避免人数过多且不能覆盖周末

故选择顺序为  3   4   1   2

注意1比二先是因为1需要先覆盖周末的白天


最后需要注意理解的就是:每一种 schedule 可以看做每天都有人工作,因为我们用循环代替了


#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;#define INF 1000000000int main()
{int n1,n2,n3;int a1,a2,a3,a4;//freopen("in.txt","r",stdin);freopen("guards.in","r",stdin);freopen("guards.out","w",stdout);while(scanf("%d%d%d",&n1,&n2,&n3)!=EOF){int p1,p2,p3;int k1,k2,k3;int sum,MIN=INF;int t1,t2,t3,t4;///四种上班方式for(t3=0;;t3++){///枚举第三种上班方式p1=n1-2*t3,p2=n2-2*t3,p3=n3-t3;for(t4=0;;t4++){k1=p1-3*t4,k2=p2,k3=p3-2*t4;t1=max(0,max(k2,k3));///占据上夜班或者周末白班t2=max(0,k1-t1);///因为循环问题,安排去周末白班的最后也会到工作日白班sum=t1*3+t2+t3*4+t4*5;if(sum<=MIN)MIN=sum,a1=t1*3,a2=t2,a3=t3*4,a4=t4*5;if(k1<=0&&k3<=0)///注意k2没变化,所以不能再这里判断break;}if(p1<=0&&p2<=0&&p3<=0)break;}printf("%d %d %d %d\n",a1,a2,a3,a4);}return 0;
}


这篇关于G - Guards Gym - 101334G 贪心 枚举 题意好难懂啊的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/706092

相关文章

Kotlin 枚举类使用举例

《Kotlin枚举类使用举例》枚举类(EnumClasses)是Kotlin中用于定义固定集合值的特殊类,它表示一组命名的常量,每个枚举常量都是该类的单例实例,接下来通过本文给大家介绍Kotl... 目录一、编程枚举类核心概念二、基础语法与特性1. 基本定义2. 带参数的枚举3. 实现接口4. 内置属性三、

C#之枚举类型与随机数详解

《C#之枚举类型与随机数详解》文章讲解了枚举类型的定义与使用方法,包括在main外部声明枚举,用于表示游戏状态和周几状态,枚举值默认从0开始递增,也可手动设置初始值以生成随机数... 目录枚举类型1.定义枚举类型(main外)2.使用生成随机数总结枚举类型1.定义枚举类型(main外)enum 类型名字

C语言自定义类型之联合和枚举解读

《C语言自定义类型之联合和枚举解读》联合体共享内存,大小由最大成员决定,遵循对齐规则;枚举类型列举可能值,提升可读性和类型安全性,两者在C语言中用于优化内存和程序效率... 目录一、联合体1.1 联合体类型的声明1.2 联合体的特点1.2.1 特点11.2.2 特点21.2.3 特点31.3 联合体的大小1

C++11作用域枚举(Scoped Enums)的实现示例

《C++11作用域枚举(ScopedEnums)的实现示例》枚举类型是一种非常实用的工具,C++11标准引入了作用域枚举,也称为强类型枚举,本文主要介绍了C++11作用域枚举(ScopedEnums... 目录一、引言二、传统枚举类型的局限性2.1 命名空间污染2.2 整型提升问题2.3 类型转换问题三、C

Java 枚举的基本使用方法及实际使用场景

《Java枚举的基本使用方法及实际使用场景》枚举是Java中一种特殊的类,用于定义一组固定的常量,枚举类型提供了更好的类型安全性和可读性,适用于需要定义一组有限且固定的值的场景,本文给大家介绍Jav... 目录一、什么是枚举?二、枚举的基本使用方法定义枚举三、实际使用场景代替常量状态机四、更多用法1.实现接

C 语言中enum枚举的定义和使用小结

《C语言中enum枚举的定义和使用小结》在C语言里,enum(枚举)是一种用户自定义的数据类型,它能够让你创建一组具名的整数常量,下面我会从定义、使用、特性等方面详细介绍enum,感兴趣的朋友一起看... 目录1、引言2、基本定义3、定义枚举变量4、自定义枚举常量的值5、枚举与switch语句结合使用6、枚

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

C#实现获得某个枚举的所有名称

《C#实现获得某个枚举的所有名称》这篇文章主要为大家详细介绍了C#如何实现获得某个枚举的所有名称,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... C#中获得某个枚举的所有名称using System;using System.Collections.Generic;usi

Java 枚举的常用技巧汇总

《Java枚举的常用技巧汇总》在Java中,枚举类型是一种特殊的数据类型,允许定义一组固定的常量,默认情况下,toString方法返回枚举常量的名称,本文提供了一个完整的代码示例,展示了如何在Jav... 目录一、枚举的基本概念1. 什么是枚举?2. 基本枚举示例3. 枚举的优势二、枚举的高级用法1. 枚举

Rust中的Option枚举快速入门教程

《Rust中的Option枚举快速入门教程》Rust中的Option枚举用于表示可能不存在的值,提供了多种方法来处理这些值,避免了空指针异常,文章介绍了Option的定义、常见方法、使用场景以及注意事... 目录引言Option介绍Option的常见方法Option使用场景场景一:函数返回可能不存在的值场景