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 ...
随机推荐
- 零基础入门学习Python(8)--了不起的分支和循环2
前言 上节课小甲鱼教大家如何正确的打飞机,其要点是判断和循环,判断就是该不该做某事,循环就是持续做某事 知识点 写一个程序 按照100分制,90分以上成绩为A,80到90为B,60到80为C,60以下 ...
- Python之面向对象slots与迭代器协议
Python之面向对象slots与迭代器协议 slots: # class People: # x=1 # def __init__(self,name): # self.name=name # de ...
- IP_MULTICAST_LOOP
WINDOWS 中 该选项仅控制接收部分.即设置为0 则控制套接字无法接收自身消息.设置为1 则控制套接字使能接收自身消息. LINUX 中 该先项仅控制发送部分.即设置为0 则控制套 ...
- matplotlib的使用--折线图--入门
目录 matplotlib应用介绍 一天天气变化图 两小时随机温度图 中文显示问题 个人交往统计图 多人交往统计图 总结 介绍: 举个例子(一天天气变化图): 假设一天中每隔两个小时(range(2, ...
- C51 使用端口 个人笔记
使用整个端口的8个引脚: 八个引脚,需要8位2进制,2位十六进制 #define P0 led led = 0x3f; //led = ~0x3f; 使用某个端口的某一个引脚 sbit led = P ...
- 使用JS对form的内容验证失败后阻止提交
1.form的两个事件 submit,提交表单,如果直接调用该函数,则直接提交表单 onSubmit,提交按钮点击时先触发,然后触发submit事件.如果不加控制的话,默认返回true,因此表单总能提 ...
- 全文搜索(AB-2)-权重
概念 权重是一个相对的概念,针对某一指标而言.某一指标的权重是指该指标在整体评价中的相对重要程度.权重是要从若干评价指标中分出轻重来,一组评价指标体系相对应的权重组成了权重体系. 释义 等同于比重 ...
- 【转】Intellij IDEA 快捷键大全
IntelliJ Idea 常用快捷键列表 Ctrl+Shift + Enter,语句完成“!”,否定完成,输入表达式时按 “!”键Ctrl+E,最近的文件Ctrl+Shift+E,最近更改的文件Sh ...
- msp430入门编程04
msp430中C语言的变量与数据类型 msp430入门学习 msp430入门编程
- Thinkphp5.0 控制器向视图view赋值
Thinkphp5.0 控制器向视图view的赋值 方式一(使用fetch()方法的第二个参数赋值): <?php namespace app\index\controller; use thi ...