[状压dp]洛谷 P2157 学校食堂

题目描述

小F 的学校在城市的一个偏僻角落,所有学生都只好在学校吃饭。学校有一个食堂,虽然简陋,但食堂大厨总能做出让同学们满意的菜肴。当然,不同的人口味也不一定相同,但每个人的口味都可以用一个非负整数表示。 由于人手不够,食堂每次只能为一个人做菜。做每道菜所需的时间是和前一道菜有关的,若前一道菜的对应的口味是a,这一道为b,则做这道菜所需的时间为(a or b)-(a and b),而做第一道菜是不需要计算时间的。其中,or 和and 表示整数逐位或运算及逐位与运算,C语言中对应的运算符为“|”和“&”。

学生数目相对于这个学校还是比较多的,吃饭做菜往往就会花去不少时间。因此,学校食堂偶尔会不按照大家的排队顺序做菜,以缩短总的进餐时间。

虽然同学们能够理解学校食堂的这种做法,不过每个同学还是有一定容忍度的。也就是说,队伍中的第i 个同学,最多允许紧跟他身后的Bi 个人先拿到饭菜。一旦在此之后的任意同学比当前同学先拿到饭,当前同学将会十分愤怒。因此,食堂做菜还得照顾到同学们的情绪。 现在,小F 想知道在满足所有人的容忍度这一前提下,自己的学校食堂做完这些菜最少需要多少时间。

输入输出格式

输入格式:

第一行包含一个正整数C,表示测试点的数据组数。 每组数据的第一行包含一个正整数N,表示同学数。 每组数据的第二行起共N行,每行包含两个用空格分隔的非负整数Ti和Bi,表示按队伍顺序从前往后的每个同学所需的菜的口味和这个同学的忍受度。 每组数据之间没有多余空行。

 

输出格式:

包含C行,每行一个整数,表示对应数据中食堂完成所有菜所需的最少时间。

 

输入输出样例

输入样例#1:
2
5
5 2
4 1
12 0
3 3
2 2
2
5 0
4 0
输出样例#1:
16
1

说明

对于第一组数据:

同学1允许同学2或同学3在他之前拿到菜;同学2允许同学3在他之前拿到菜;同学3比较小气,他必须比他后面的同学先拿菜……

一种最优的方案是按同学3、同学2、同学1、同学4、同学5做菜,每道菜所需的时间分别是0、8、1、6及1。

【数据规模和约定】

对于30%的数据,满足1 ≤ N ≤ 20。

对于100%的数据,满足1 ≤ N ≤ 1,000,0 ≤ Ti ≤ 1,000,0 ≤ Bi ≤ 7,1 ≤ C ≤ 5。

存在30%的数据,满足0 ≤ Bi ≤ 1。

存在65%的数据,满足0 ≤ Bi ≤ 5。

存在45%的数据,满足0 ≤ Ti ≤ 130。

 

 

题解

  • 首先,发现能容忍的人数最多只有7个
  • 那很容易就可以记录下8个人状态
  • 可以考虑下状压dp
  • 设f[i][j][k]表示1~i-1人都打完饭,后面i~i+7个人的状态为j,上一次打饭是第i+k个人的需要的最少时间
  • 如果当前j&1为真,也就是说第i个是打过饭的
  • 那么可以直接转移到f[i+1][j>>1][k1]
  • 可以最后一个打饭的人的编号为(i+1)+(k-1)=i+k和f[i][j][k]表示的一样
  • 而第 i个人也打完了饭,所以满足「第 1 个人到第 i 个人已经打完饭」这个条件
  • 而 j>>1 就是说 i 之后的第 1 个人就是 i+1 之后的第 0 个人(就是 i+1 本人)
  • i 之后的第 2 个人就是 i+1 之后的第 1 个人,i 之后的第 3 个人就是 i+1 之后的第 2 个人,…。
  • 这样就可以看出意义一样了。
  • 如果当前j&1为假,那我们i是不能转移到i+1的
  • 因为第i个人没打饭
  • 那这是,如果要满足需要的最少时间
  • 那我们只能在他的忍耐限度内枚举出一个最小的,并转移
  • 但是要记得我们这个方程的上一次选的人是第i+k个人,而不是第i个人

 

 

代码

#include<cmath>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
const int INF=0x3f3f3f3f;
int n,t[1005],b[1005],f[1005][1<<8][20];
void work() 
{int r;scanf("%d",&n);for (int i=1;i<=n;i++) scanf("%d%d",&t[i],&b[i]);memset(f,INF,sizeof(f));f[1][0][7]=0;for (int i=1;i<=n;i++) for (int j=0;j<(1<<8);j++)for (int k=-8;k<=7;k++) if (f[i][j][k+8]!=INF) {if (j&1) f[i+1][j>>1][k+7]=min(f[i+1][j>>1][k+7],f[i][j][k+8]);else {r=INF;for (int h=0;h<=7;h++) if (!((j>>h)&1)) {if (i+h>r) break;r=min(r,i+h+b[i+h]);f[i][j|(1<<h)][h+8]=min(f[i][j|(1<<h)][h+8],f[i][j][k+8]+(i+k?(t[i+k]^t[i+h]):0));}}}int ans=INF;for (int k=0;k<=8;k++) ans=min(ans,f[n+1][0][k]);printf("%d\n",ans);
}
int main()
{int t;scanf("%d",&t);while (t--) work();return 0;
}

  

 

转载于:https://www.cnblogs.com/Comfortable/p/9205408.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/465676.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

怎么得到自增列的下一个会插入的id

代码 1declareTable_namevarchar(60) 2setTable_namePay_inputpay; 3Selectso.name Table_name, --表名字4sc.name Iden_Column_name, --自增字段名字5ident_current(so.name) curr_value, --自增字段当前值6ident_incr(so.name) incr_value,…

ESP32,使用gitee搭建 ESP-IDF 开发框架

ESP32便宜&#xff0c;开发方便&#xff0c;非常适合初学者用来学习&#xff0c;之前我自己写的开发环境可能不再适合&#xff0c;推荐下面这篇文章。关于如何搭建ESP32的开发环境&#xff0c;乐鑫官方给出了很详细的教程和文档&#xff0c;基本上跟着官方教程来操作&#xff0…

jQuery的ajax技术

编辑本博客 ajax异步的JavaScript和html load() 从服务器加载数据&#xff0c;并把返回的数据放入备选元素中。这里加载回来的数据可以只有一个p标签&#xff0c;无需head元素等 $("selector").load(url,data,callback) url&#xff1a;必选&#xff0c;规定加载的ur…

Python3——FTP(文件传输协议)

Python3——FTP&#xff08;文件传输协议&#xff09; 工作流程&#xff1a; 客户端连接远程主机的FTP服务器&#xff1b;客户端输入用户名密码&#xff1b;客户端进行各种文件传输和信息查询&#xff1b;客户端从FTP服务器退出。ftplib.FTP常用方法 login(user,passwd)登录 …

Linux设备树的传递以及kernel中对设备树的解析

当U-Boot将设备树加载到内存指定位置后&#xff0c;ARM内核的SoC以通用寄存器r2来传递dtb在内存中的地址。kernel获取到该地址后对dtb文件做进一步的处理。#设备树的传递当使用bootm加载kernel镜像时&#xff08;bootz是对bootm的一种封装以及功能扩展&#xff0c;实质一样&…

切片基础slice

定义&#xff1a;slice表示一个拥有相同类型元素的可变长度的序列 slice有三个属性&#xff1a;指针&#xff0c;长度&#xff0c;容量 指针指向第一个可以从slice中访问的元素&#xff0c;这个元素并不一定是数组的第一个元素 注意&#xff1a; 1.一个底层数组可以对应多个sli…

常用shell命令

要复制整个目录&#xff0c;请使用 cp 命令的 -r 选项。例如&#xff0c;如果有一个名为 mydir 的目录&#xff0c;其中包含 myfile 和 newfile&#xff0c;则可以将该目录复制到一个名为 mydir2 的新目录。mydir2 还将包含 myfile 和 newfile 的副本。请使用以下命令&#xff…

Linux kernel之SMP初始化

01—SMP数据结构SMP的数据结构如下图所示&#xff0c;主要由2部分构成&#xff0c;通过两个宏定义CONFIG_SMP和CONFIG_HOT_PLUG来控制。当设置kernel支持SMP模式时&#xff0c;那么CONFIG_SMP选项是一定会打开的&#xff0c;因此第一部分是必须实现的内容。而第二部分是否需要实…

Python3——多线程之threading模块

Python3——多线程之threading模块 目录 Python3——多线程之threading模块 Threading模块的对象 Threading模块的Thread类 queue模块&#xff08;线程间通信&#xff09; Python 提供了多个模块来支持多线程编程&#xff0c;包括 thread、 threading 和 Queue 模块等。程…

BZOJ2216 [Poi2011]Lightning Conductor 【决策单调性dp】

题目链接 BZOJ2216 题解 学过高中数学都应知道&#xff0c;我们要求\(p\)的极值&#xff0c;参变分离为\[h_j sqrt{|i - j|} - h_i \le p\] 实际上就是求\(h_j sqrt{|i - j|} - h_i\)的最大值 就可以设\(f[i]\)表示对\(i\)最大的该式的值 绝对值通常要去掉&#xff0c;一般可…

笔记本 cpu 参数

选本必看--笔记本主流cpu参数大全现在本本的处理器种类真的太多了&#xff0c;绝对足够让人眼花缭乱的&#xff0c;各式各样的CPU核心、外频、缓存、接口、电压、制作工艺等等&#xff0c;多到让人疯狂&#xff0c;很少认能够对此了如执掌的。这次我们归纳了所有主流的本本处理…

MTK笔试1题~

这个题目是前几天一个好友分享给我的&#xff0c;但是因为时间原因没有及时写成文章。这是他参加MTK笔试的题目题目如下&#xff1a;网友提供的代码如下&#xff1a;#include "stdio.h"typedef struct n{int data;struct n* next;struct n* pre; }*pnode;int main(){…

console和windows子系统

https://blog.csdn.net/ilvu999/article/details/8050292 转载于:https://www.cnblogs.com/132818Creator/p/9210791.html

Python3 —— 逗号分隔值CSV

Python3 —— 逗号分隔值CSV 目录 Python3 —— 逗号分隔值CSV CSV 读写CSV文件 CSV 逗号分隔值&#xff08; Comma-Separated Value&#xff0c; CSV&#xff09;。与专有的二进制文件格式截然不同&#xff0c; CSV 通常用于在电子表格软件和纯文本之间交互数据。CSV 文件…

教你如何防止电脑插入u盘后自动运行

今天重装了系统&#xff0c;安装了驱动和各种软件&#xff0c;然后打完了补丁。在使用的过程中&#xff0c;当我插入U盘的时候发现是自动打开的&#xff0c;那么怎样防止这一个现象呢&#xff1f;思考片刻我想到了本地组策略&#xff0c;于是找了一下&#xff0c;结果还真有一个…

从单片机步入Linux之运行地址与加载地址

大家好&#xff0c;我是情报小哥&#xff01;本文为【单片机步入嵌入式Linux】系列文章的第二篇&#xff0c;主要是跟大家讲解一下链接过程中几个地址的区分与理解~01单片机存储分配

VC++常见错误

1、fatal error C1010: unexpected end of file while looking for precompiled header directive。寻找预编译头文件路径时遇到了不该遇到的文件尾。&#xff08;一般是没有#include "stdafx.h"&#xff09; 2、fatal error C1083: Cannot open include file: R………

iview插件

1.图表居中 columns1: [{title: 序号,key: number,align: center, //水平居中}, } 转载于:https://www.cnblogs.com/SunShineM/p/9217335.html

Python3——JSON

Python3——JSON 目录 Python3——JSON Python和JSON数据类型对比 dumps()/loads() JSON是JavaScript的子集&#xff0c;专门用于指定结构化的数据。JSON 是轻量级的数据交换方式&#xff0c;易于阅读和编写。 Python和JSON数据类型对比 dict object list,tuple array …

不要错过秋招

标题就是重点~这是今天跟一个同学聊天说到的问题&#xff0c;之前我不是直播了嘛&#xff0c;我在直播里面说&#xff0c;如果大家有求职面试相关的事情&#xff0c;可以私下找我&#xff0c;这位同学还是很积极&#xff0c;今天就找我聊了。他的简历整体上问题不大&#xff0c…