更好的阅读体验

我的博客观看

T1-Buying A House

给你一个长度为n的序列a,给你目标房子m,最多花的钱k

如果a[i]为0,这座房子无法购买,否则可以购买,求能买的距离目标房子最近的房子,输出最小距离

两座房子之间距离为10

解法

显然贪心的从目标房子开始左右扫就可以了

ac代码

#include<bits/stdc++.h>
using namespace std;
int n,m,lim,ans,a[110];
int main()
{
scanf("%d%d%d",&n,&m,&lim);
for(int i=1;i<=n;i++)scanf("%d",&a[i]);
for(int i=1;;i++)
{
if(m-i>=1)if(a[m-i]&&a[m-i]<=lim){ans=i;break;}
if(m+i<=n)if(a[m+i]&&a[m+i]<=lim){ans=i;break;}
}
printf("%d\n",ans*10);
return 0;
}

T2-Find The Bone

一个长度为n的线段,线段上有m个坑,k次操作,骨头一开始在1,每次操作给定x,y,交换x,y,如果骨头掉到坑里,就会一直在那里,求最后骨头所在位置

解法

模拟一遍就好了QAQ

ac代码

#include<bits/stdc++.h>
using namespace std;
int n,m,k,x,y,ans=1,a[1000010];
int main()
{
scanf("%d%d%d",&n,&m,&k);
for(int i=1;i<=m;i++)scanf("%d",&x),a[x]=1;
for(int i=1;i<=k;i++)
{
scanf("%d%d",&x,&y);
if(x==ans&&!a[x])ans=y;
else if(y==ans&&!a[y])ans=x;
}
printf("%d\n",ans);
return 0;
}

T3-Bank Hacking

给定一棵带点权树,选出一个最佳的根节点,使得根节点的点权不变,它的儿子点权加1,其余点点权加2,并使最大点权最小,输出这个最小的最大点权

解法

暴力的对每一个点扫它所有的儿子,然后check,设ans为原来的最大值,答案只可能是ans,ans+1,ans+2,复杂度是n+m

ac代码

#include<bits/stdc++.h>
using namespace std;
struct node{int to,next;}e[600010];
int n,cnt=0,res,ans=-0x3f3f3f3f,flg,x,y,a[300010],head[300010];
map<int,int>mp;
void add(){e[++cnt]={y,head[x]},head[x]=cnt,e[++cnt]={x,head[y]},head[y]=cnt;}
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)scanf("%d",&a[i]),mp[a[i]]++,ans=max(ans,a[i]);
res=ans+2;
for(int i=1;i<n;i++)scanf("%d%d",&x,&y),add();
for(int i=1;i<=n;i++)
{
flg=0;
for(int j=head[i];j;j=e[j].next){mp[a[e[j].to]]--;if(a[e[j].to]==ans)flg=1;}
if(!mp[ans])res=ans+1;
if(ans==a[i]&&mp[ans]==1)
{
if(mp[ans-1])res=ans+1;
else if(flg)res=ans+1;
else{res=ans;break;}
}
for(int j=head[i];j;j=e[j].next)mp[a[e[j].to]]++;
}
printf("%d\n",res);
return 0;
}

T4-Police Stations

给定一棵树,树上有一些点是警察局,要求所有点到最近的警察局的距离不大于d,求最多能删几条边

解法

建一个超级源连着所有警察局,或者一开始就把所有警察局压入队列,跑bfs

如果这条边过去的点被访问过,那这条边就可以删除

bfs的退出条件不是点有没有被搜过,而是边有没有被搜索和距离是否超过d

ac代码

#include<bits/stdc++.h>
using namespace std;
struct node{int to,next,v;}e[600010];
struct Node{int num,d;};
int n,k,d,cnt=1,ans=0,x,y,head[300010],vis[300010],flg[300010],res[300010];
queue<Node>q;
void add(){e[++cnt]={y,head[x],0},head[x]=cnt,e[++cnt]={x,head[y],0},head[y]=cnt;}
void bfs()
{
while(!q.empty())
{
Node u=q.front();
q.pop();
flg[u.num]=0;
if(u.d>d)continue;
for(int i=head[u.num];i;i=e[i].next)
{
if(e[i].v)continue;
e[i].v=e[i^1].v=1;
if(vis[e[i].to])res[++ans]=i/2;
if(!flg[e[i].to])q.push({e[i].to,u.d+1}),flg[e[i].to]=vis[e[i].to]=1;
}
}
}
int main()
{
scanf("%d%d%d",&n,&k,&d);
for(int i=1;i<=k;i++)scanf("%d",&x),q.push({x,0}),vis[x]=1;
for(int i=1;i<n;i++)scanf("%d%d",&x,&y),add();
bfs(),printf("%d\n",ans);
for(int i=1;i<=ans;i++)printf("%d ",res[i]);
return 0;
}

T5-Exam Cheating

muronglin是个学渣,考试的时候,她一道题也不会做

她的左右桌分别是学霸chhokmah和学霸lukelin,虽然学霸并不是题题都会做,但他们做了的题一定都对

现在muronglin想要作弊,但是为了不被监考员抓住,她最多偷看p次,一次能看连续的k道题

给定n和la和lb,分别为题目总数,chhokmah做出题目数和lukelin做出题目数,再给出两位学霸做出题目序列,问muronglin最多能偷看到几道题的答案

解法

可以看出是个dp,设dp[i][j][x][y]表示前i个问题,用j次机会,chhokmah还能看x道题,lukelin还能看y道题的最优值

转移时分情况讨论,如果都没有机会,分4种:都不偷看,偷看任意1位,偷看2位

如果任意1位没有机会,分3种:只偷看1位,偷看2位,重新开始偷看2位

如果都有机会,就顺着模拟

ac代码

#include<bits/stdc++.h>
#define get(x,y) x=max(x,y)
#define FOR(i,a,b) for(int i=a;i<=b;i++)
using namespace std;
int n,p,k,la,lb,ans=0,x,y=1,a[1010],b[1010],dp[2][1010][60][60];
int main()
{
memset(dp,-0x3f,sizeof(dp)),dp[0][0][0][0]=0,scanf("%d%d%d",&n,&p,&k);
scanf("%d",&la);FOR(i,1,la)scanf("%d",&x),a[x]=1;
scanf("%d",&lb);FOR(i,1,lb)scanf("%d",&x),b[x]=1;
if(p*k>=2*n){FOR(i,1,n)ans+=a[i]|b[i];printf("%d\n",ans);return 0;}
FOR(i,1,n)
{
x=y,y^=1,memset(dp[x],-0x3f,sizeof(dp[x]));
FOR(j,0,p)FOR(ii,0,k)FOR(jj,0,k)if(!ii&&!jj)
{
get(dp[x][j][0][0],dp[y][j][0][0]);
get(dp[x][j+1][k-1][0],dp[y][j][0][0]+a[i]);
get(dp[x][j+1][0][k-1],dp[y][j][0][0]+b[i]);
get(dp[x][j+2][k-1][k-1],dp[y][j][0][0]+(a[i]|b[i]));
}
else if(!ii)
{
get(dp[x][j][0][jj-1],dp[y][j][0][jj]+b[i]);
get(dp[x][j+1][k-1][jj-1],dp[y][j][0][jj]+(a[i]|b[i]));
get(dp[x][j+2][k-1][k-1],dp[y][j][0][jj]+(a[i]|b[i]));
}
else if(!jj)
{
get(dp[x][j][ii-1][0],dp[y][j][ii][0]+a[i]);
get(dp[x][j+1][ii-1][k-1],dp[y][j][ii][0]+(a[i]|b[i]));
get(dp[x][j+2][k-1][k-1],dp[y][j][ii][0]+(a[i]|b[i]));
}
else get(dp[x][j][ii-1][jj-1],dp[y][j][ii][jj]+(a[i]|b[i]));
}
FOR(l,0,p)FOR(i,0,k)FOR(j,0,k)get(ans,dp[x][l][i][j]);printf("%d\n",ans);
return 0;
}

hgoi#20190516的更多相关文章

  1. HGOI 20181028 题解

    HGOI 20181028(复赛备考) /* 真是暴力的一天,最后一题MLE?由于数组开得太大了!!! 270滚粗 考场上好像智商高了很多?!(假的) */ sol:暴力求解,然后没有数据范围吐槽一下 ...

  2. HGOI NOIP模拟4 题解

    NOIP国庆模拟赛Day5 题解 T1 马里奥 题目描述 马里奥将要参加 NOIP 了,他现在在一片大陆上,这个大陆上有着许多浮空岛,并且其中一座浮空岛上有一个传送门,马里奥想要到达传送门从而前往 N ...

  3. HGOI 20191106

    HGOI 20191106 t1 旅行家(traveller) 2s,256MB [题目背景] 小X热爱旅行,他梦想有一天可以环游全世界-- [题目描述] 现在小X拥有n种一次性空间转移装置,每种装置 ...

  4. 「HGOI#2019.4.19省选模拟赛」赛后总结

    t1-Painting 这道题目比较简单,但是我比较弱就只是写了一个链表合并和区间DP. 别人的贪心吊打我的DP,嘤嘤嘤. #include <bits/stdc++.h> #define ...

  5. HGOI 20190407 Typing Competition Round #1 出题记

    /* ljc20020730出的HGOI20190407的模拟赛. 考试结果比预期难的不少,可能是由于本来计划5h的比赛打了4h吧. 就当普及组模拟赛好了... 难度大概4紫吧(弱省省选难度) 出境 ...

  6. HGOI 20190310 题解

    /* 又是又双叒叕WA的一天... 我太弱鸡了... 今天上午打了4道CF */ Problem 1 meaning 给出q组询问,求下列函数的值$ f(a) = \max\limits_{0 < ...

  7. [hgoi#2019/3/21]NOIP&NOI赛后总结

    前言 今天做的是是2010年提高组和NOI的题目,做过几道原题,但是还是爆炸了,我真的太弱了. t1-乌龟棋 https://www.luogu.org/problemnew/show/P1541 这 ...

  8. HGOI 20190303 题解

    /* 记一串数字真难. 5435 今天比赛又是hjcAK的一天. 今天开题顺序是312,在搞T1之前搞了T3 昨天某谷月赛真是毒瘤. 但是讲评的同学不错,起码T4看懂了... 构造最优状态然后DP的思 ...

  9. HGOI 20180224 题解

    /* The Most Important Things: ljc chat with fyh on QQTa说期末考Ta数学74分感觉不好但是我觉得fyh是地表最强的鸭~~(of course en ...

随机推荐

  1. 解决无法定位程序输入点SymEnumSymbols于动态链接库dbghelp.dll

    作者:朱金灿 来源:http://blog.csdn.net/clever101 下载一个源码,使用VS2008编译链接无问题,运行时出现一个错误:无法定位程序输入点SymEnumSymbols于动态 ...

  2. [Linux] ssh秘钥对免密码登陆

    准备两台linux服务器 a和b , 在a上使用ssh命令登陆b服务器 , 并且不用 输入密码 1.在a服务器上,比如是root用户 ,进去/root/.ssh目录 ,没有就创建, 就是进入家目录的. ...

  3. WPF依赖属性(续)(1)

    原文:WPF依赖属性(续)(1)                 之前有写过几篇文章,详细地介绍了依赖属性的基本使用方法,如果你不想了解其内部实现机制的话,那么通过那两篇文章的介绍,足以应付平时的应用 ...

  4. Qt图片自适应窗口控件大小(使用setScaledContents)

    最近在用Qt设计一个小程序,想让一幅图片自适应窗口大小,由于本人比较笨,一直找不到好方法.找到了很多方法但都会出一些小问题, 刚刚摸索出解决办法了,在些记录. 思想: 1 显示图像是用QLabel2 ...

  5. 2 WCF里面配置的含义

    1 首先介绍所谓的a,b,c. a就是address 地址: b binding 绑定的协议 譬如http  tcp udp 利用这些协议方式请求address: c contract  代表请求的规 ...

  6. 用WPF窗体打造个性化界面的图片浏览器

    原文:用WPF窗体打造个性化界面的图片浏览器 本文使用WPF窗体(XAML及C#)与Win Form控件(FolderBrowserDialog)结合的方式, 演示制作了一个简易漂亮的WPF图片浏览器 ...

  7. 统计web訪问前10的ip

    cat access.log|awk '{print $0}'|sort|uniq -c|sort -nr|head -n 10

  8. qt4.8.7 源码在win7+vs2010环境的x64编译(qt 64位)

    由于qt官网上,没有直接提供x64的安装包,但由于项目需要x64的qt,所以,小编不得不下载qt的源码,经历了一次长达约4个小时的编译过程.今年国庆7天,就遭这事上了,哈哈~~~ 几个下载链接: qt ...

  9. cefsharp 与webbrowser简单对比概述

    原文:cefsharp 与webbrowser简单对比概述 有个项目需要做个简单浏览器,从网上了解到几个相关的组件有winform自带的IE内核的WebBrowser,有第三方组件谷歌内核的webki ...

  10. WPF 窗体显示最前端

    原文:WPF 窗体显示最前端 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/jjx0224/article/details/8782845 如何做一 ...