假设对于任意一种药品,每天开始工作时的库存总量已知,并且一天之内不会通过进货的方式增加。每天会有很多病人前来取药,每个病人希望取走不同数量的药品。如果病人需要的数量超过了当时的库存量,药房会拒绝该病人的请求。管理员希望知道每天会有多少病人没有取上药。
【输入】
共3行,第一行是每天开始时的药品总量m。
第二行是这一天取药的人数n(0<n<=100)。
第三行共有n个数,分别记录了每个病人希望取走的药品数量(按照时间先后的顺序)。
【输出】
只有1行,为这一天没有取上药品的人数。
【输入样例】
30
6
10 5 20 6 7 8
【输出样例】
2
题目分析:因为是简单考试,所以不用设计类或者结构体
1、根据题目分析需要创建变量用来表示药房剩余的药品数量,以及没取上药的人数
2、定义取的次数n,然后用来循环n次,每次循环输入取药数量,若取的数量比剩余药品大,说明剩余药品不能满足取药,没取上药的人数增加1。若取的数量比剩余药品小,则成功取药,剩余药品减少。
3、循环结束后,输出没取上药的值
这个题其实是循环判断的一个变体,一般我们做的题是满足条件累加,而题目变成了累减。同样是统计个数。可以参考满足条件的奇数偶数的题型。
#include<iostream>
using namespace std;
int main()
{//s定义为剩余药品//n是取药的次数int s, n;//a定义每个人取药数量 d定义没有取上药的人数 //有的需要初始化,有的不需要的原因是因为马上就要输入了int a, d = 0;cin >> s >> n;for(int i = 0; i < n; ++i){//输入取药数量cin >> a;if(s < a)//如果药不够了d++;//没取上药人数增加elses -= a;//药品数量减少} cout << d;return 0;
}
上面就是最基础的药房管理的内容。
当然我们如果学过后面的技能,可以给他适当的完善一下。
(扩展)使用类和方法来实现
#include <iostream>
#include <vector>// 药品类
class Medicine {
public:int stock; // 库存量Medicine(int initial_stock) : stock(initial_stock) {}// 处理病人请求bool processRequest(int request) {if (stock >= request) {stock -= request;return true; // 请求成功}return false; // 请求失败}
};int main() {using namespace std;int initialStock, requestsCount;cin >> initialStock >> requestsCount; // 输入初始库存量和请求次数Medicine medicine(initialStock); // 创建药品实例int failedRequests = 0; // 未满足的请求计数for (int i = 0; i < requestsCount; ++i) {int request;cin >> request; // 输入每个病人的请求量if (!medicine.processRequest(request)) {failedRequests++; // 如果请求失败,增加计数}}cout << "未取到药的病人数量: " << failedRequests << endl;return 0;
}
与上面的核心思想基本一样,只不过封装了一个类和方法。帮助我们很好的拆分和低耦合整个模块。
好了,有任何问题,我们评论区聊聊吧。