[ACM] FZU 2086 餐厅点餐 (枚举)
roblem Description
Jack近期喜欢到学校餐厅吃饭。好吃干净还廉价。
在学校餐厅。有a种汤,b种饭。c种面条,d种荤菜,e种素菜。
为了保证膳食搭配,Jack每顿饭都会点1~2样荤菜,1~2样素菜(不反复)。同一时候,在Jack心情好的时候,会点一样饭,再配上一种汤。在心情不好的时候,就仅仅吃一种面条。
由于经济有限,Jack每次点餐的总价在min~max之间。
Jack想知道,总共同拥有多少种不同的点餐方案。
Input
输入数据第一行包括一个整数T,表示測试数据的组数。对于每组測试数据:
第一行为整数a,b,c,d,e(0<a,b,c,d,e<=10)
第二行为a个大于零的整数,表示a种汤的价格
第三行为b个大于零的整数,表示b种饭的价格
第四行为c个大于零的整数,表示c种面条的价格
第五行为d个大于零的整数,表示d种荤菜的价格
第六行为e个大于零的整数,表示e种素菜的价格
第七行为两个整数min max,表示每次点餐的价格范围
Output
Sample Input
Sample Output
Source
福州大学第九届程序设计竞赛
解题思路:
又是由于没看清题意。
。。
点餐不光要有荤有素,还必须有饭汤或面条。
代码:
#include <iostream>
#include <string.h>
#include <algorithm>
#include <stdio.h>
#include <iomanip>
#include <cmath>
#include <stack>
#include <queue>
#include <map>
#include <vector>
#include <ctype.h>
using namespace std;
int tang,fan,mian,hun,su;
int Tang[11],Fan[11],Mian[11],Hun[11],Su[11];
int Min,Max; bool ok(int n)
{
if(n>=Min&&n<=Max)
return true;
return false;
}
int p[100000]; int main()
{
int t;cin>>t;
while(t--)
{
cin>>tang>>fan>>mian>>hun>>su;
for(int i=1;i<=tang;i++)
scanf("%d",&Tang[i]);
for(int i=1;i<=fan;i++)
scanf("%d",&Fan[i]);
for(int i=1;i<=mian;i++)
scanf("%d",&Mian[i]);
for(int i=1;i<=hun;i++)
scanf("%d",&Hun[i]);
for(int i=1;i<=su;i++)
scanf("%d",&Su[i]);
cin>>Min>>Max;
int cnt=0;
int len=0; for(int i=1;i<=hun;i++)//一荤一素
{
if(Hun[i]>=Max)
continue;
for(int j=1;j<=su;j++)
{
if(Su[j]>=Max)
continue;
int temp=Hun[i]+Su[j];
if(temp<Max)
p[++len]=temp;
}
}
for(int i=1;i<=hun;i++)//一荤两素
{
if(Hun[i]>=Max)
continue;
for(int j=1;j<=su;j++)
{
if(Su[j]>=Max)
continue;
for(int k=j+1;k<=su;k++)
{
if(Su[k]>=Max)
continue;
int temp=Hun[i]+Su[j]+Su[k];
if(temp<Max)
p[++len]=temp;
}
}
}
for(int i=1;i<=hun;i++)//两荤一素
{
if(Hun[i]>=Max)
continue;
for(int j=i+1;j<=hun;j++)
{
if(Hun[j]>=Max)
continue;
for(int k=1;k<=su;k++)
{
if(Su[k]>=Max)
continue;
int temp=Hun[i]+Hun[j]+Su[k];
if(temp<Max)
p[++len]=temp;
}
}
} for(int i=1;i<=hun;i++)//两荤两素
{
if(Hun[i]>=Max)
continue;
for(int j=i+1;j<=hun;j++)
{
if(Hun[j]>=Max)
continue;
for(int s=1;s<=su;s++)
{
if(Su[s]>=Max)
continue;
for(int q=s+1;q<=su;q++)
{
if(Su[q]>=Max)
continue;
int temp=Hun[i]+Hun[j]+Su[s]+Su[q];
if(temp<Max)
p[++len]=temp;
}
}
}
}
for(int i=1;i<=len;i++)
{
for(int fan1=1;fan1<=fan;fan1++)
{
int p1=p[i];
p1+=Fan[fan1];
int d=p1;
for(int tang1=1;tang1<=tang;tang1++)
{
p1=d;//注意这一句
p1+=Tang[tang1];
if(ok(p1))
cnt++;
}
}
for(int mian1=1;mian1<=mian;mian1++)
{
int p2=p[i];
p2+=Mian[mian1];
if(ok(p2))
cnt++;
}
}
cout<<cnt<<endl;
}
return 0;
}
[ACM] FZU 2086 餐厅点餐 (枚举)的更多相关文章
- FZU 2086 餐厅点餐(模拟)
Problem 2086 餐厅点餐 Problem Description Jack最近喜欢到学校餐厅吃饭,好吃干净还便宜. 在学校餐厅,有a种汤,b种饭,c种面条,d种荤菜,e种素菜. 为了保证膳食 ...
- FZU 2086 餐厅点餐(枚举)
///个人感觉vector好看一点 #include<iostream> #include<cstdio> #include<cstring> #include&l ...
- FZU 2086 餐厅点餐
好久不写博客了……得有快一个月了……看到大神们一篇篇博文 唉……差好多……这一个月 有蓝桥杯还有校赛……校赛签到题都没签完 实力铁牌……不过蓝桥杯一等奖 五月份帝都之行还挺令人期待……清明小长假之前 ...
- 餐厅点餐APP总结
总结:经过这几个月的时间里,我们通过学习.讨论一起做出了餐厅点餐这个APP,我们在做这个APP的过程中,每个人都有自己的想法,也通过讨论最后做出了这个app,虽然做的不是很好,但是我们也尽自己的努力尽 ...
- 安卓餐厅点餐系统---针对浩然android工作室的一个小白的分析
昨天刚把浩然android工作室的下载下来了,为了研究下点餐系统的架构,更好的完成手中的项目,便写出一个分析报告(小白的分析,忘见谅!) 本项目app主要用于餐厅无线订餐使用,功能突出餐厅的订餐需求, ...
- iOS- UIPickerView餐厅点餐系统
在餐厅里的点餐系统的核心控件就是UIPickerView 今天晚上在整理以前的项目笔记时,特意把UIPickerView单独拿出来,做了一个简陋的点餐道具. 因为没有素材图片,所有大家将就看看吧 0. ...
- ACM/ICPC 之 三维计算几何+暴力枚举+判重(HDU5839)
CCPC网赛第八题,求立体几何数量,题解见注释 //立体几何-求满足要求的四面体个数 //要求1:至少4条边相等 //要求2:四条边相等时,另两条边一定不相邻(即对边) //题解:以当前边为不相邻的其 ...
- ACM: FZU 2105 Digits Count - 位运算的线段树【黑科技福利】
FZU 2105 Digits Count Time Limit:10000MS Memory Limit:262144KB 64bit IO Format:%I64d & ...
- ACM: FZU 2107 Hua Rong Dao - DFS - 暴力
FZU 2107 Hua Rong Dao Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I6 ...
随机推荐
- TWaver版3D化学元素周期表
非常早就有人做3D网页版的化学元素周期表了.酷炫效果和新奇技巧一度被众多粉丝奉为神明,争相研究和效仿.甚至有人放弃一切扑向这颗蜡烛.不由总是想到那个OPPO广告女主角拽拽的歧视道:"辞职去旅 ...
- 14-spring学习-变量操作
表达式所有操作都是可以以变量形式出现的. 观察变量的定义: package com.Spring.ELDemo; import org.springframework.expression.Evalu ...
- 那些最好的轮子 - PHP篇
转载于:http://avnpc.com/pages/best-wheels-for-php 在关于不要重复造轮子的二三事一文中,交代了一些背景和想法.本篇则完全是一些干货,列举一些我用过或者即将会用 ...
- mfc获取控件在对话框上的位置
CRect rect; GetDlgItem(控件ID)->GetWindowRect(&rect);//获取控件的屏幕坐标ScreenToClient(&rect);//转换为 ...
- 转 redis使用场景 简介
Redis实战(五) 聊聊Redis使用场景 发表于 2016-11-21 | 数据存储 | Redis 文章目录 1. 使用场景说明 1.1. 计数器 1.2. 排行榜 1.3. 用于存储时间戳 1 ...
- Java Persistence with MyBatis 小结3
1 映射器配置文件和映射器接口 在 com.mybatis3.mappers 包中的 StudentMapper.xml 配置文件内,是如何配置 id 为”findStudentById”的 SQL ...
- iOS图片上传及处理
从摄像头或者是从相冊中读取图片.须要通过UIImagePickerController类来实现,在使用UIImagePickerController时,须要是实现以下两个协议 <UINaviga ...
- hdoj4864 Task (贪心)
题目来源: 2014 Multi-University Training Contest 1--by FZU 题意:有N个机器和m个工作.机器和工作都有一个时间xi和价值yi,一个工作仅仅有满足xi和 ...
- 安卓开发学习2-官方例子Accelerometer
1.使用WakeLock防止屏幕被锁住,如果用户自己锁住屏幕,下次再开的时候还会重置一下,防止被锁. 2.SimulationView接收传感器事件,并且绘制.它实现SensorEventListen ...
- 06、Windows 10 技术预览
随着 Windows 10 发布的,未来 Windows 平台都是统一开发模型,可以只写一个 Appx 包,就可以同时部署到 Windows/ Windowsw Phone/ Tablet /xbox ...