[LUOGU] NOIP提高组模拟赛Day1
题外话:以Ingress为题材出的比赛好评,绿军好评
T1
考虑枚举第\(i\)个人作为左边必选的一个人,那左边剩余\(i-1\)个人,选法就是\(2^{i-1}\),也就是可以任意选或不选,右侧剩余\(n-i\)个人,选法就是\(\sum\limits_{j=1}^{n-i}C_{n-i}^j\),容易发现就是\(2^{n-i}-1\)种选法,于是第i个人的贡献就是\(2^{i-1}\times(2^{n-i}-1)\),化简式子即可得到答案。
#include<iostream>
#include<cstdio>
using namespace std;
typedef long long ll;
const ll MOD = 1e9+7;
ll qpow(ll x,ll y){
ll ret=1;
while(y){
if(y&1)(ret*=x)%=MOD;
y>>=1ll;(x*=x)%=MOD;
}
return ret;
}
ll n;
int main(){
cin>>n;
n--;
ll ans=(qpow(2ll,n)*(n-1ll))%MOD+1;
cout<<ans;
return 0;
}
T2
发现\(T[i]\)就是物品体积,\(C[i]\)就是物品价值,背包大小就是\(D[i]\)
按\(D[i]\)升序枚举每个元素,做背包即可
统计答案?逆序枚举状态即可
#include<algorithm>
#include<iostream>
#include<cstdio>
#include<cctype>
#include<vector>
using namespace std;
inline int rd(){
int ret=0,f=1;char c;
while(c=getchar(),!isdigit(c))f=c=='-'?-1:1;
while(isdigit(c))ret=ret*10+c-'0',c=getchar();
return ret*f;
}
const int MAXN = 2005;
int n;
struct Node{
int t,d,c,id;
bool operator<(const Node &rhs)const{
return d<rhs.d;
}
}a[MAXN];
int f[MAXN];
bool vis[MAXN][MAXN];
vector<int> vec[MAXN];
int ans=0;
int sta[MAXN],top;
int main(){
n=rd();
for(int i=1;i<=n;i++){
a[i].t = rd();
a[i].d = rd();
a[i].c = rd();
a[i].id = i;
}
sort(a+1,a+1+n);
for(int i=1;i<=n;i++){
for(int j=a[i].d;j>a[i].t;j--){
if(f[j]<f[j-a[i].t]+a[i].c){
f[j]=f[j-a[i].t]+a[i].c;
vis[i][j]=1;
}
}
}
int ansid=0;
for(int i=0;i<=a[n].d;i++){
if(f[i]>f[ans]) ans=i;
}
cout<<f[ans]<<endl;
for(int i=n;i>=1;i--){
if(vis[i][ans]){
sta[++top]=a[i].id;
ans-=a[i].t;
}
}
cout<<top<<endl;
while(top) cout<<sta[top--]<<" ";
return 0;
}
T3
类似一个流量平衡的问题
本着NOIP不考网络流的思想,先写了高斯消元,发现自由元极多,很复杂,就弃坑了
开始想网络流,拆点套路题,S向左侧点连\(A[i]\)的边,右侧点向T连\(B[i]\)的边,点的流量可以流给自己,也可以给别人,分别建向自己的边和向相连的点的边即可
判断有解就看T的入边是否均满流,统计答案就记录点之间的边的流量
#include<iostream>
#include<cstring>
#include<cctype>
#include<cstdio>
#include<queue>
using namespace std;
const int MAXN=100005;
const int INF=1<<30;
int n,m,s,t;
int mxflow;
inline int rd(){
int ret=0,f=1;char c;
while(c=getchar(),!isdigit(c))f=c=='-'?-1:1;
while(isdigit(c))ret=ret*10+c-'0',c=getchar();
return ret*f;
}
struct Edge{
int next,to,w;
}e[MAXN*10];
int ecnt=1,head[MAXN],cur[MAXN];
inline void adds(int x,int y,int w){
e[++ecnt].next = head[x];
e[ecnt].to = y;
e[ecnt].w = w;
head[x] = ecnt;
}
inline void add(int x,int y,int w){
adds(x,y,w);adds(y,x,0);
}
int dis[MAXN];
queue<int> Q;
bool bfs(){
memset(dis,0,sizeof(dis));
Q.push(s);dis[s]=1;
while(!Q.empty()){
int top=Q.front();Q.pop();
for(int i=head[top];i;i=e[i].next){
int v=e[i].to;
if(dis[v]||!e[i].w) continue;
Q.push(v);dis[v]=dis[top]+1;
}
}
return dis[t];
}
int dfs(int x,int val){
if(x==t) return val;
int used=0,tmp;
for(int i=cur[x];i;i=e[i].next){
int v=e[i].to;
if(dis[v]!=dis[x]+1) continue;//
tmp=dfs(v,min(val-used,e[i].w));
used+=tmp;
e[i].w-=tmp;
e[i^1].w+=tmp;
if(e[i].w) cur[x]=i;
if(val==used) return val;
}
if(!used) dis[x]=0;
return used;
}
void dinic(){
while(bfs()){
memcpy(cur,head,sizeof(head));
mxflow+=dfs(s,INF);
}
}
int A[MAXN],B[MAXN];
int ans[256][256];
int main(){
//magic spj :)
n=rd();m=rd();
s=n*2+1,t=s+1;
int x,y,w;
for(int i=1;i<=n;i++)A[i]=rd();
for(int i=1;i<=n;i++)B[i]=rd();
for(int i=1;i<=n;i++){
add(s,i,A[i]);
add(i+n,t,B[i]);
add(i,i+n,INF);
}
for(int i=1;i<=m;i++){
int x,y;
x=rd();y=rd();
add(x,y+n,INF);
add(y,x+n,INF);
}
dinic();
for(int i=n+1;i<=n+n;i++){
for(int j=head[i];j;j=e[j].next){
int v=e[j].to;
if(v!=t) continue;
if(e[j].w) return puts("NO"),0;
}
}
puts("YES");
for(int i=1;i<=n;i++){
for(int j=head[i];j;j=e[j].next){
int v=e[j].to;
if(v==s) continue;
ans[i][v-n]+=e[j^1].w;
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
printf("%d",ans[i][j]);
if(j!=n)putchar(' ');
}
if(i!=n)putchar('\n');
}
return 0;
}
[LUOGU] NOIP提高组模拟赛Day1的更多相关文章
- HGOI2010816 (NOIP 提高组模拟赛 day1)
Day1 210pts(含T1莫名的-10pts和T3莫名的-30pts) 100+70+40=210 rank 29 这道题第一眼看是字符串匹配问题什么KMP啊,又想KMP不会做啊,那就RK Has ...
- 【洛谷】NOIP提高组模拟赛Day1【组合数学】【贪心+背包】【网络流判断是否满流以及流量方案】
U41568 Agent1 题目背景 2018年11月17日,中国香港将会迎来一场XM大战,是世界各地的ENLIGHTENED与RESISTANCE开战的地点,某地 的ENLIGHTENED总部也想派 ...
- 洛谷 NOIP提高组模拟赛 Day1
传送门 ## $T1$ 一道结论题,设原来A队能力最大的是x,那么A队的选择方案就是$2^{x-1}$,B队的选择方案就是$(2^{n-x}-1)$种,因为不能不选.其中$1\leq x\leq n$ ...
- 计蒜客 2017 NOIP 提高组模拟赛(四)Day1 T2 小X的密室
https://nanti.jisuanke.com/t/17323 小 X 正困在一个密室里,他希望尽快逃出密室. 密室中有 N 个房间,初始时,小 X 在 1号房间,而出口在 N号房间. 密室的每 ...
- 10-18 noip提高组模拟赛(codecomb)T1倍增[未填]
T1只想到了找环,> <倍增的思想没有学过,所以看题解看得雨里雾里的(最近真的打算学一下! 题目出的挺好的,觉得noip极有可能出现T1T2T3,所以在此mark 刚开始T1以为是模拟,还 ...
- HGOI20180815 (NOIP 提高组模拟赛 day2)
Day 2 rank 11 100+35+30=165 本题是一道数论题,求ax+by=c的正整数对(x,y) x>=0并且y>=0 先说下gcd: 求a,b公约数gcd(a,b) 如gc ...
- 10-18 noip提高组模拟赛(codecomb)T2贪心
T2:找min:一直找最小的那个,直到a[i]-x+1小于0,就找次小的,以此类推: 求max,也是一样的,一直到最大的那个,直到次大的比之前最大的大,就找次大的: 这个模拟,可以用上priority ...
- 【洛谷】NOIP提高组模拟赛Day2【动态开节点/树状数组】【双头链表模拟】
U41571 Agent2 题目背景 炎炎夏日还没有过去,Agent们没有一个想出去外面搞事情的.每当ENLIGHTENED总部组织活动时,人人都说有空,结果到了活动日,却一个接着一个咕咕咕了.只有不 ...
- noip提高组模拟赛(QBXT)T2
T2count题解 [ 问题描述]: 小 A 是一名热衷于优化各种算法的 OIER,有一天他给了你一个随机生成的 1~n 的排列, 并定 义区间[l,r]的价值为: \[ \huge C_{l,r}= ...
随机推荐
- NFS服务及DHCPD服务
NFS 服务 Linux与Linux之间的文件共享 就是网络文件系统,依靠网络. 所有端口都存放在此,对应的服务跟端口 cat /etc/service 部署NFS 先部署服务器端: 部署之前要先启用 ...
- Python数据科学手册Seaborn马拉松可视化里时分秒转化为秒数的问题
Python数据科学手册Seaborn马拉松可视化里时分秒转化为秒数的问题 问题描述: 我实在是太懒了,问题描述抄的网上的哈哈哈:https://www.jianshu.com/p/6ab7afa05 ...
- [Java]基本数据类型及其封装类总结
九种基本数据类型的大小,以及他们的封装类 类型 字节 默认值 封装类 byte 1 0 Byte char 2 null Character int 4 0 Integer long 8 0 Long ...
- 维护gcd的线段树 补发一波。。。
基础线段树(辣鸡的不行) 发现自己线段树除了会维护加法和乘法就啥也不会了QWQ太菜了 瞎写了一个维护gcd的 首先,gcd(x,y)= gcd(x,y-x) 并且很容易推广到n个数,所以我们可以把原数 ...
- Hive进阶_开发Hive的自定义函数
Hive中的自定义函数简介 (1) 在类中创建自定义函数.自定义UDF需要继承'org.apache.hadoop.hive.ql.exec.UDF',实现evaluate函数,evaluate函数支 ...
- c++笔记1
using namespace std:命名空间可以保证一些命名能够在全局不冲突.如用户可以通过声明命名空间,然后用运算符::区别同名的不同变量 using namespace std;namespa ...
- 【踩坑】springMVC 接收String参数没有判断为空
今天在调试iReview项目的接口时,发现新增词条和新增库的时候,某些字段即使留空POST到后台时也能当做不为空. 经过排查,发现后台是使用 String 变量名 == null 这样的语句去判断变量 ...
- springboot+shiro+cas实现单点登录之shiro端搭建
github:https://github.com/peterowang/shiro-cas 本文如有配置问题,请查看之前的springboot集成shiro的文章 1.配置ehcache缓存,在re ...
- qrcode length overflow (1632>1056)--qrcode.js使用过程中二维码长度溢出解决办法
近日在开发过程中需要为页面动态生成一个二维码信息,由于这个二维码中包含了很多文字,字母以及符号,测试过程中发现有些二维码会报错,因为二维码内容太多了,没办法显示.后来在GitHub中找到了解决办法. ...
- 动态代理案例1:运用Proxy动态代理来增强方法
动态代理案例1: /*要求:运用Proxy动态代理来增强方法 题目: 1.定义接口Fruit,其中有addFruit方法 2.定义实现类FruitImpl,实现Fruit接口 3.定 ...