试题 算法训练 学做菜

问题描述

涛涛立志要做新好青年,他最近在学做菜。由于技术还很生疏,他只会用鸡蛋,西红柿,鸡丁,辣酱这四种原料来做菜,我们给这四种原料标上字母A,B,C,D。
  涛涛现在会做的菜有五种:
  1、 西红柿炒鸡蛋 原料:AABDD
  2、 酸辣鸡丁 原料:ABCD
  3、 宫保鸡丁 原料:CCD
  4、 水煮西红柿 原料:BBB
  5、 怪味蛋 原料:AD
  这天早上,开开去早市给涛涛买了一些原料回来。由于事先没有什么计划,涛涛决定,对于现存的原料,每次尽量做菜单上靠前(即编号小)的菜。
  现在请你写一个程序,判断一下开开和涛涛中午能吃到哪些菜。

输入格式

共4个整数a,b,c,d。分别表示开开买的A,B,C,D这4种原料的数量。每种原料不会超过30份。

输出格式

输出5行。其中第i行表示涛涛做的第i种菜的数目。

样例输入

3
1
2
4

样例输出

1
0
1
0
1

代码

#include <iostream>
#include <iomanip>
#include<cmath>
#include<algorithm>
#include<cstring>
#include<string>
using namespace std;
int c[5];
int main()
{
    for(int i=0;i<4;i++)
    {
    	cin>>c[i];
	}
	for(int i=1;;i++)
	{
		c[0]-=2;
		c[1]-=1;
		c[3]-=2;
		if(c[0]<0||c[1]<0||c[3]<0)
		{
			c[0]+=2;
			c[1]+=1;
			c[3]+=2;
			cout<<i-1<<endl;
			break;
		}
	}
	for(int i=1;;i++)
	{
		c[0]-=1;
		c[1]-=1;
		c[2]-=1;
		c[3]-=1;
		if(c[0]<0||c[1]<0||c[3]<0||c[2]<0)
		{
			c[0]+=1;
			c[1]+=1;
			c[2]+=1;
			c[3]+=1;
			cout<<i-1<<endl;
			break;
		}
	}
	for(int i=1;;i++)
	{
		c[2]-=2;
		c[3]-=1;
		if(c[3]<0||c[2]<0)
		{
			c[2]+=2;
			c[3]+=1;
			cout<<i-1<<endl;
			break;
		}
	}
	for(int i=1;;i++)
	{
		c[1]-=3;
		if(c[1]<0)
		{
			c[1]+=3;
			cout<<i-1<<endl;
			break;
		}
	}
	for(int i=1;;i++)
	{
		c[0]-=1;
		c[3]-=1;
		if(c[0]<0||c[3]<0)
		{
			c[0]+=1;
			c[3]+=1;
			cout<<i-1<<endl;
			break;
		}
	}
	return 0; 
}
"1402做菜顺序"这个表述似乎不完整,可能是想问的是“如何使用贪心算法来确定最优的做菜顺序”。在烹饪或任务调度中,贪心算法可以用来优化步骤安排,通常是在每一步中选择当前看起来最好的或者最有利的选择,希望这些局部最优解最终汇聚成全局最优解。 举个例子,假设你有若干道菜需要准备,每道菜都有开始和结束时间,贪心算法的步骤可能如下: 1. **初始化**:收集所有菜品的信息,如开始时间(start_time)和结束时间(end_time)。 2. **排序**:按照结束时间升序排列菜品,因为你想尽快完成那些用时短的菜,以便腾出时间其他菜品。 3. **选择**:从时间上最早的菜品开始,按照这个顺序依次做菜。 4. **贪心决策**:在每一步都选择剩余菜品中最早完成的那道。 **贪心证明**(如果这是你要的)通常是通过构造一个满足贪心策略的最优解,并证明无论初始状态如何,只要遵循这个策略,最终结果都是最优的。然而,贪心算法并不总是能得到全局最优解,比如某些情况下可能存在依赖关系(即一道菜必须在另一道菜完成后才能开始),这时就需要更复杂的策略,如动态规划。 如果你对特定的数证明或者烹饪中的贪心算法应用有兴趣,可以提供更详细的问题,我会给出更精确的解释和证明方法。相关问题: 1. 你能具体描述一个烹饪场景下的贪心算法例子吗? 2. 如何证明这个做菜顺序是局部最优的? 3. 哪些情况下贪心算法做菜顺序不是全局最优?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值