D1 模拟赛
T1 note 数组开小 菜的真实 60分
题目大意:
一个字符串 分成若干段 使每段内都没有重复的字符 求最少的段数
思路:
可以贪心
#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<vector>
#include<queue>
#define inf 2139062143
#define ll long long
#define MAXN 601010
using namespace std;
inline int read()
{
int x=,f=;char ch=getchar();
while(!isdigit(ch)) {if(ch=='-') f=-;ch=getchar();}
while(isdigit(ch)) {x=x*+ch-'';ch=getchar();}
return x*f;
}
char ch[MAXN];
int n,ans,hsh[];
int main()
{
freopen("note.in","r",stdin);
freopen("note.out","w",stdout);
scanf("%s",ch+);
int n=strlen(ch+);
for(int i=;i<=n;i++)
{
if(hsh[ch[i]-'a']) {memset(hsh,,sizeof(hsh));ans++;}
hsh[ch[i]-'a']=;
}
printf("%d",ans+);
}
T2 work 顺利a掉
题目大意:
一个数列A 取一些数 不能取连续k个数 求取的数的最大值
思路:
把问题转化为k个里面必须取一个 求取的数的最小值
可以使用单调队列优化dp
#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<vector>
#include<queue>
#define inf 2139062143
#define ll long long
#define MAXN 201010
using namespace std;
inline ll read()
{
ll x=,f=;char ch=getchar();
while(!isdigit(ch)) {if(ch=='-') f=-;ch=getchar();}
while(isdigit(ch)) {x=x*+ch-'';ch=getchar();}
return x*f;
}
ll n,k,a[MAXN],dp[MAXN],q[MAXN],l,r,s,ans=inf;
int main()
{
freopen("work.in","r",stdin);
freopen("work.out","w",stdout);
n=read(),k=read();
for(int i=;i<=n;i++) a[i]=read(),s+=a[i];
q[l=r=]=;
for(int i=;i<=n;i++)
{
while(l<r&&q[l]<i-k) l++;
dp[i]=dp[q[l]]+a[i];
while(l<r&&dp[i]<dp[q[r]]) r--;
q[++r]=i;
}
ans=dp[n];
for(int i=n-k+;i<n;i++)
ans=min(ans,dp[i]);
printf("%lld",s-ans);
}
T3 cave 在熊神的帮助下a掉
题目大意:
一棵树 每条边有边权x 走该条边会花费x点能量 可以重复走一条边 并会消耗2*x点能量
q次询问 每次询问k点能量可以最多走过多少个不同的点
思路:
首先可以想到dp i j 0/1 表示第i个点 用j点能量 进入子树是否回到i点 表示可以走过的最多不同点的个数
发现能量可能很大 就把 j 和dp表达的值调换
dp i j 0/1 表示第i个点 走j个不同点 进入子树是否回到i点 花费的最少能量
然后对于每个子树做背包
方程见代码
#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<vector>
#include<queue>
#define inf 2139062143
#define ll long long
#define MAXN 530
using namespace std;
inline int read()
{
int x=,f=;char ch=getchar();
while(!isdigit(ch)) {if(ch=='-') f=-;ch=getchar();}
while(isdigit(ch)) {x=x*+ch-'';ch=getchar();}
return x*f;
}
int n,fst[MAXN],nxt[MAXN<<],to[MAXN<<],val[MAXN<<],cnt;
int sz[MAXN],dp[MAXN][MAXN][],t[MAXN][];
void add(int u,int v,int w) {nxt[++cnt]=fst[u],fst[u]=cnt,to[cnt]=v,val[cnt]=w;}
void dfs(int x,int fa)
{
sz[x]=;
for(int i=fst[x];i;i=nxt[i])
if(to[i]!=fa) {dfs(to[i],x);sz[x]+=sz[to[i]];}
}
void dfs(int x)
{
dp[x][][]=dp[x][][]=;
for(int i=fst[x];i;i=nxt[i])
if(sz[to[i]]<sz[x]) dfs(to[i]);
for(int j=fst[x];j;j=nxt[j])
if(sz[to[j]]<sz[x])
{
memset(t,,sizeof(t));
for(int i=;i<=sz[x];i++)
for(int k=;k<=min(sz[to[j]],i-);k++)
{
t[i][]=min(t[i][],min(dp[x][i-k][]+dp[to[j]][k][]+val[j],dp[x][i-k][]+dp[to[j]][k][]+*val[j]));//从这个该儿子的子树里出来进入别的儿子的树或从别的儿子的树出来进入该儿子的树
t[i][]=min(t[i][],dp[x][i-k][]+dp[to[j]][k][]+*val[j]);//需要从以儿子为根的树出来并从别的子树出来
}
//t数组因为忘记了背包要倒着dp导致需要t数组来保证不会改变被用到的dp值
for(int i=;i<=sz[x];i++)
dp[x][i][]=min(t[i][],dp[x][i][]),dp[x][i][]=min(t[i][],dp[x][i][]);
}
}
int main()
{
freopen("cave.in","r",stdin);
freopen("cave.out","w",stdout);
n=read();int a,b,c,res;
for(int i=;i<n;i++) {a=read(),b=read(),c=read();add(a,b,c);add(b,a,c);}
int T=read();memset(dp,,sizeof(dp));
dfs(,);dfs();
while(T--)
{
a=read(),res=;
for(int i=n;i>=;i--) if(dp[][i][]<=a) {res=i;break;}
printf("%d\n",res);
}
}
D1 模拟赛的更多相关文章
- 7.29NOIP模拟赛
7.29NOIP模拟赛 T1 YSG (1s,64MB,ysg.in,ysg.out) 描述 ysg,yxy,azw 三人正在刷题. 他们每做一题的时间都是一个有理数. 如果在某一时刻,三人同时做完一 ...
- NOI.AC: NOIP2018 全国模拟赛习题练习
闲谈: 最后一个星期还是不浪了,做一下模拟赛(还是有点小虚) #30.candy 题目: 有一个人想买糖吃,有两家商店A,B,A商店中第i个糖果的愉悦度为Ai,B商店中第i个糖果的愉悦度为Bi 给出n ...
- NOIP模拟赛20161022
NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...
- NOI模拟赛 Day1
[考完试不想说话系列] 他们都会做呢QAQ 我毛线也不会呢QAQ 悲伤ING 考试问题: 1.感觉不是很清醒,有点困╯﹏╰ 2.为啥总不按照计划来!!! 3.脑洞在哪里 4.把模拟赛当作真正的比赛,紧 ...
- NOIP第7场模拟赛题解
NOIP模拟赛第7场题解: 题解见:http://www.cqoi.net:2012/JudgeOnline/problemset.php?page=13 题号为2221-2224. 1.car 边界 ...
- contesthunter暑假NOIP模拟赛第一场题解
contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...
- NOIP模拟赛 by hzwer
2015年10月04日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...
- 小奇模拟赛9.13 by hzwer
2015年9月13日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿(explo) [题目背景] 小奇要开采一些矿物,它驾驶着一台带有钻头(初始能力值w)的飞船,按既定路线依次飞 ...
- PKUSC 模拟赛 day1 下午总结
下午到了机房之后又困又饿,还要被强行摁着看英文题,简直差评 第一题是NOIP模拟赛的原题,随便模拟就好啦 本人模拟功力太渣不小心打错了个变量,居然调了40多分钟QAQ #include<cstd ...
随机推荐
- Java的类加载
虚拟机把描述类的数据从Class文件加载到内存,并对数据进行校验.转换解析和初始化,最终形成可以被虚拟机直接使用的Java类型,这就是Java虚拟机的类加载机制 ----类加载的大致过程 类的加载的过 ...
- Error opening session. Cause: java.lang.NullPointerExcept.
在学mybatis时遇到这个问题,后面发现时打错了一个字母,发现后分享出来,如果发现这个错误也能够更好的排除错误. 如图可以发现我不小心把default打成了defaule所以出现了这个错误,也找了好 ...
- [Python3网络爬虫开发实战] 1.9.6-Gerapy的安装
Gerapy是一个Scrapy分布式管理模块,本节就来介绍一下它的安装方式. 1. 相关链接 GitHub:https://github.com/Gerapy 2. pip安装 这里推荐使用pip安装 ...
- docker配置国内加速器
一.登录到daocloud网站后选择如下地址的加速器 二.根据配置提示在linux上执行对应的配置命令: curl -sSL https://get.daocloud.io/daotools/set_ ...
- 85-Momentum 动量指标.(2015.7.3)
Momentum 动量指标 动量数值就是当天价格同前几个时段的价格的比率 MOMENTUM = CLOSE(i)/CLOSE(i-N)*100 注解: CLOSE(i) - 当前柱形的收市价格: CL ...
- MyBaties 异常之 java.lang.UnsupportedOperationException
sql语句 对应的接口为: 包错误的详情为: java.lang.UnsupportedOperationException 原因: resultType返回的是集合中的元素类型,而不是集合本身 SQ ...
- allegro中查看寄生参数
在allegro中可以查看线的寄生参数,这个命令所在的位置在如下如位置: 版权声明:本文为博主原创文章,未经博主允许不得转载.
- MySQL中间件之ProxySQL_读写分离/查询重写配置
MySQL中间件之ProxySQL_读写分离/查询重写配置 Posted on 2016-12-25 by mark blue, mark Leave a comment MySQL 1.闲扯几句 读 ...
- 关于java对于大数处理的相关程序和用法
<span style="font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; font-size: 13px; l ...
- Django用法补充
1. 自定义Admin from django.contrib import admin from xx import models # 自定义操作 class CustomerAdmin(admin ...