HGOI 20191029am 题解
Promblem A 小G的字符串
给定$n,k$,构造一个长度为$n$,只能使用$k$种小写字母的字符串。
要求相邻字符不能相同且$k$种字母都要出现
输出字典序最小的字符串,无解输出$-1$。
对于$100\%$的数据满足$\leq n \leq 10^5$
Solution :
我们考虑构造,显然是形如$a,b,a,b,...,c,d...$的字符串。
即从$[1,n-k+2]$交替填$a,b$,然后$[n-k+3,n]$依次填$c,d,e ... $
这样构造的时间复杂度是$O(n)$
# pragma GCC optimize()
# include <bits/stdc++.h>
using namespace std;
const int N=1e5+;
char ans[N];
int n,k;
int main() {
freopen("str.in","r",stdin);
freopen("str.out","w",stdout);
scanf("%d%d",&n,&k);
if (k == && n == ) {
puts("a"); return ;
}
if (k > n || k ==) {
puts("-1"); return ;
}
char now='c';
for (int i=n-k+;i<=n;i++) ans[i]=now++;
int op = ;
for (int i=;i<n-k+;i++,op=-op) ans[i]='a'+op;
for (int i=;i<=n;i++) putchar(ans[i]);
puts("");
return ;
}
str.cpp
Promblem B 小G的城堡
给定$n,k$,构造一幅有向图,每个点出度为$1$。
使$[1,k]$的点都能走到$1$,$[k+1,n]$的点都不能走到$1$
输出方案数对$10^9 + 7$取模后的值。
对于$100\%$的数据满足$n\leq 10^{18} , k \leq \min\{n,8\}$
Solution :
我们将点分为$[1,k]$和$[k+1,n]$两部分来考虑。
第$1$部分的点进行连边,使得所有点都能走到$1$,对于上述数据范围直接$dfs$即可(事实上答案为$k^{k-1}$)。
第$2$部分的点随意连边即可,显然方案数$(n-k) ^ {n-k}$ 。
所以最后的答案就是$k^{k-1} (n-k)^{n-k}$。
时间复杂度就是$O(log_2 n )$。
# pragma GCC optimize()
# include<bits/stdc++.h>
# define int long long
using namespace std;
const int mo=1e9+;
const int d[] = {,,,,,,,,};
int Pow(int x,int n) {
int ans=;
while (n) {
if(n&) ans=ans*x%mo;
x=x*x%mo;
n>>=;
}
return ans%mo;
}
signed main()
{
freopen("castle.in","r",stdin);
freopen("castle.out","w",stdout);
int n,k; cin >> n >> k;
int ans = Pow((n-k)%mo,n-k) * d[k] % mo;
cout<<ans<<'\n';
return ;
}
castle.cpp
Promblem C 小G坐电梯
在长度为$n$的数轴上起点为$A$,限制点为$B$(限制点不能被经过)
你可以走$k$步,每次从$x$点走到$y(x \neq y)$点需要满足$x$到$y$的距离小于$x$到$B$的距离。
输出方案数对$10^9 + 7$取模后的值。
对于$100\%$的数据满足$n ,k \leq 5000 $
Solution :
可以考虑一个$O(n^2k)$的暴力dp,设$f[i][j]$表示当前第$i$次走动后处在第$j$个位置,方案数。
考虑刷表,$f[i][j]$能转移到$f[i+1][k]$的条件是$k\neq j$且$|j-k|<|j-B|$,有转移$f[i+1][k]+=f[i][j]$
本题的状态数$O(n^2)$,考虑优化转移.
容易发现,每一次的刷表转移是一个区间加的过程,需要在最后维护每个单点的值。
也就说,当前状态为$(i,j)$, 对于 $k \in [\max\{j-|j-B|+1,1\} , \min\{n,j+|j-B|-1\}] , k \neq j$ 的 $f[i+1][k]$ 都可以被转移到,即区间加$f[i][j]$。
直接差分就好了。
于是转移就变成均摊$O(1)$的。
总时间复杂度为$O(nk)$
# pragma GCC optimize()
# include <bits/stdc++.h>
# define int long long
using namespace std;
const int N=5e3+;
const int mo=1e9+;
int n,A,B,k;
int f[N],c[N];
signed main()
{
freopen("lift.in","r",stdin);
freopen("lift.out","w",stdout);
cin >> n >> A >> B >> k; f[A]=;
for (int i=;i<k;i++) {
for (int j=;j<=n;j++) c[j]=;
for (int j=;j<=n;j++) {
int ret = abs(j-B);
int l = max(j-ret+,1ll),r = min(n,j+ret-);
(c[l]+=f[j])%=mo; (c[r+]+=mo-f[j])%=mo;
if (j>=l&&j<=r) (c[j]+=mo-f[j])%=mo,(c[j+]+=f[j])%=mo;
}
for (int j=;j<=n;j++) (c[j]+=c[j-])%=mo,f[j]=c[j];
}
int ans=;
for (int i=;i<=n;i++) (ans+=f[i])%=mo;
cout<< ans << '\n';
return ;
}
lift.cpp
HGOI 20191029am 题解的更多相关文章
- HGOI 20181028 题解
HGOI 20181028(复赛备考) /* 真是暴力的一天,最后一题MLE?由于数组开得太大了!!! 270滚粗 考场上好像智商高了很多?!(假的) */ sol:暴力求解,然后没有数据范围吐槽一下 ...
- HGOI 20190310 题解
/* 又是又双叒叕WA的一天... 我太弱鸡了... 今天上午打了4道CF */ Problem 1 meaning 给出q组询问,求下列函数的值$ f(a) = \max\limits_{0 < ...
- HGOI 20190303 题解
/* 记一串数字真难. 5435 今天比赛又是hjcAK的一天. 今天开题顺序是312,在搞T1之前搞了T3 昨天某谷月赛真是毒瘤. 但是讲评的同学不错,起码T4看懂了... 构造最优状态然后DP的思 ...
- HGOI 20180224 题解
/* The Most Important Things: ljc chat with fyh on QQTa说期末考Ta数学74分感觉不好但是我觉得fyh是地表最强的鸭~~(of course en ...
- HGOI 20190218 题解
/* 又是AK局... hjc又双叒叕AK了... Hmmm...我侥幸 */ Problem A card 给出无序序列a[]可以选择一个数插入到合适的位置作为一次操作,至少多少次操作后可以把序列变 ...
- HGOI 20190217 题解
/* for me,开训第一天 /beacuse 文化课太差被抓去补文化课了... 看一眼题 : AK局? 但是,Wa on test #10 in problem C 290! (就差那么一咪咪) ...
- HGOI 20181103 题解
problem:把一个可重集分成两个互异的不为空集合,两个集合里面的数相乘的gcd为1(将集合中所有元素的质因数没有交集) solution:显然本题并不是那么容易啊!考场上想了好久.. 其实转化为上 ...
- HGOI 20181101题解
/* 又是爆0的一天(不知道今年高考难不难,反正今天(信息学)真的难!) */ solution:对于两个数相加,有一个显然的结论就是要么不进位(相对于位数大的),要么(进最多一位) 然后对于整个数组 ...
- HGOI 20191108 题解
Problem A 新婚快乐 一条路,被$n$个红绿灯划分成$n+1$段,从前到后一次给出每一段的长度$l_i$,每走$1$的长度需要$1$分钟. 一开始所有红绿灯都是绿色的,$g$分钟后所有红绿灯变 ...
随机推荐
- MySQ-表关系-外键-修改表结构-复制表-03
目录 前言 不合理的表结构(案例) 带来的问题 如何解决问题? 如何确定表关系? 表关系 一对多 多对多 一对一 应用场景 判断表关系最简单的语法 三种关系常见案例 如何建立表关系? 外键 forei ...
- LeetCode 160——相交链表(JAVA)
编写一个程序,找到两个单链表相交的起始节点. 如下面的两个链表: 在节点 c1 开始相交. 示例 1: 输入:intersectVal = 8, listA = [4,1,8,4,5], listB ...
- C#解决界面闪烁
添加缓冲: private void SetDoubleBuffer() { base.SetStyle( ControlStyles.OptimizedDoubleBuffer | ControlS ...
- A Pythonic Card Deck: __len__ & __getitem__ & for 循环的嵌套
1. 列表生成式的嵌套 for 循环: 示例如下: li1 = range(1,6) li2 = list("ABC") # list("ABC") 的结果为 ...
- JS基础_质数练习,用到了标记flag
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- 深入探讨java的类加载器
类加载器是 Java 语言的一个创新,也是 Java 语言流行的重要原因之一.它使得 Java 类可以被动态加载到 Java 虚拟机中并执行.类加载器从 JDK 1.0 就出现了,最初是为了满足 Ja ...
- VS2015 中统计整个项目的代码行数
在一个大工程中有很多的源文件和头文件,我如何快速统计总行数? ------解决方案--------------------b*[^:b#/]+.*$^b*[^:b#/]+.*$ ctrl + shif ...
- JavaWeb【Servlet】
概念 Servlet是在服务器上运行的小程序.一个Servlet请求对应一个Java类(对应一个Wrapper容器),可以通过请求-响应模式访问这个驻留在内存中的小程序. Tomcat容器等级 上图表 ...
- linux命令详解——iostat
简介 iostat主要用于监控系统设备的IO负载情况,iostat首次运行时显示自系统启动开始的各项统计信息,之后运行iostat将显示自上次运行该命令以后的统计信息.用户可以通过指定统计的次数和时间 ...
- linux的top下buffer与cache的区别、free命令内存解释
buffer: 缓冲区,一个用于存储速度不同步的设备或优先级不同的设备之间传输数据 的区域.通过缓冲区,可以使进程之间的相互等待变少,从而使从速度慢的设备读入数据 时,速度快的设备的操作进程不发 ...