[HNOI2010]BUS 公交线路

题面

Bzoj

Sol

状压很显然
重点在于转移:题目就相当与每\(p\)长度的车站必须有且仅有\(k\)个被经过
那么转移时状压的二进制一定要有\(k\)个一
且两个相邻转移的状态之间必须满足:设为\(i->j\),则\((i >> 1) \&j\)要有\(k-1\)个\(1\)
然后就可以加上矩阵快速幂优化,注意把满足要求的状态记下来,只有一百多个

我常数丑是我的错

# include <bits/stdc++.h>
# define RG register
# define IL inline
# define Fill(a, b) memset(a, b, sizeof(a))
using namespace std;
typedef long long ll;
const int Zsy(30031);

IL int Input(){
    RG int x = 0, z = 1; RG char c = getchar();
    for(; c < '0' || c > '9'; c = getchar()) z = c == '-' ? -1 : 1;
    for(; c >= '0' && c <= '9'; c = getchar()) x = (x << 1) + (x << 3) + (c ^ 48);
    return x * z;
}

int n, k, p, cnt[1024], que[150], len, pos;

IL void Up(RG int &x, RG int y){
    x += y;
    if(x >= Zsy) x -= Zsy;
}

struct Matrix{
    int a[150][150];

    IL Matrix(){
        Fill(a, 0);
    }

    IL int* operator [](RG int x){
        return a[x];
    }

    IL void Init(){
        for(RG int i = 0; i < len; ++i) a[i][i] = 1;
    }

    IL Matrix operator *(RG Matrix B){
        RG Matrix C;
        for(RG int i = 0; i < len; ++i)
            for(RG int j = 0; j < len; ++j)
                for(RG int l = 0; l < len; ++l)
                    Up(C[i][l], 1LL * a[i][j] * B[j][l] % Zsy);
        return C;
    }
} S, E, T;

int main(RG int argc, RG char* argv[]){
    n = Input(), k = Input(), p = Input();
    for(RG int i = 0; i < (1 << p); ++i){
        for(RG int x = i; x; x -= x & -x) ++cnt[i];
        if(cnt[i] == k && (i & 1)) que[len++] = i;
    }
    for(RG int i = 0; i < len; ++i)
        if(que[i] == (1 << k) - 1) pos = i;
    for(RG int i = 0; i < len; ++i)
        for(RG int j = 0; j < len; ++j)
            if(cnt[(que[i] >> 1) & que[j]] == k - 1) T[i][j] = 1;
    E.Init(), S[0][pos] = 1;
    for(RG int i = n - k; i; i >>= 1, T = T * T)
        if(i & 1) E = E * T;
    S = S * E;
    printf("%d\n", S[0][pos]);
    return 0;
}

原文地址:https://www.cnblogs.com/cjoieryl/p/8456429.html

时间: 2024-11-09 19:55:08

[HNOI2010]BUS 公交线路的相关文章

【BZOJ2004】[Hnoi2010]Bus 公交线路 状压+矩阵乘法

[BZOJ2004][Hnoi2010]Bus 公交线路 Description 小Z所在的城市有N个公交车站,排列在一条长(N-1)km的直线上,从左到右依次编号为1到N,相邻公交车站间的距离均为1km. 作为公交车线路的规划者,小Z调查了市民的需求,决定按下述规则设计线路: 1.设共K辆公交车,则1到K号站作为始发站,N-K+1到N号台作为终点站. 2.每个车站必须被一辆且仅一辆公交车经过(始发站和终点站也算被经过). 3.公交车只能从编号较小的站台驶往编号较大的站台. 4.一辆公交车经过的

[BZOJ2004][Hnoi2010]Bus 公交线路

试题描述 小Z所在的城市有N个公交车站,排列在一条长(N-1)km的直线上,从左到右依次编号为1到N,相邻公交车站间的距离均为1km. 作为公交车线路的规划者,小Z调查了市民的需求,决定按下述规则设计线路: 1.设共K辆公交车,则1到K号站作为始发站,N-K+1到N号台作为终点站. 2.每个车站必须被一辆且仅一辆公交车经过(始发站和终点站也算被经过). 3.公交车只能从编号较小的站台驶往编号较大的站台. 4.一辆公交车经过的相邻两个站台间距离不得超过Pkm. 在最终设计线路之前,小Z想知道有多少

BZOJ 2004: [Hnoi2010]Bus 公交线路 [DP 状压 矩阵乘法]

传送门 题意: $n$个公交站点,$k$辆车,$1...k$是起始站,$n-k+1..n$是终点站 每个站只能被一辆车停靠一次 每辆车相邻两个停靠位置不能超过$p$ 求方案数 $n \le 10^9,\ p \le 8,\ k \le 10$ 思考过程中遇到的主要问题是“所有车是同时前进的”,既不能单独考虑一辆车又没法考虑前面的车队后面的影响 正确的做法是同时考虑所有车 每$p$个位置一定每辆车各停一次 $f[i][s]$表示当前在站点$i$,且$i$有车,$s$为车停靠状态 强制规定最靠左(即

[BZOJ 2004] [Hnoi2010] Bus 公交线路 【状压DP + 矩阵乘法】

题目链接: BZOJ - 2004 题目分析 看到题目完全不会..于是立即看神犇们的题解. 由于 p<=10 ,所以想到是使用状压.将每个连续的 p 个位置压缩成一个 p 位 2 进制数,其中共有 k 位是1,表示这 k 个位置是某辆 Bus 当前停下的位置.需要注意的是,每个状态的第一位必须是 1 ,这样保证了不会有重复的状态. 每个状态可以转移到右边的某些状态(由当前状态的第一个 1 移动).初始状态和终止状态都是前面 k 位是 1 .用矩阵转移 n - k 次. 代码 #include <

[HNOI 2010]Bus 公交线路

Description 题库链接 有 \(N\) 个车站, \(K\) 条公交线路.第 \(1\) 到 \(K\) 站是这 \(K\) 线路的起点站.第 \(N-K+1\) 到 \(N\) 是终点站.车只会从编号小的车站驶向编号大的车站. 要求每个车站恰好只属于一个线路,而且同一个线路相临两站距离不得大于 \(P\) .求有多少种安排方法.输出答案对 \(30031\) 取余数. \(1\leq N\leq 10^9,1<K\leq P\leq 10,K<N\) Solution 不妨抛开前

爱帮公交查询之公交线路查询

今天,想在微信做一个公交查询的功能.到网上找了点资料,觉得爱帮挺好的于是注册了个帐号 api 页面 http://www.aibang.com/api/usage 公交线路查询 说明 公交线路查询,该接口根据关键字查询匹配的线路. 形式 http://openapi.aibang.com/bus/lines 例如:http://openapi.aibang.com/bus/lines?app_key=f41c8afccc586de03a99c86097e98ccb&city=%E5%8C%97%

公交线路免费api接口代码

描述:本接口主要是根据城市名称 +  线路名称 模糊查找城市公交线路信息. 开源api接口:http://openapi.aibang.com/bus/lines?app_key=f41c8afccc586de03a99c86097e98ccb&city="+cityName+"&q="+line 其中cityName = URLEncoder.encode(cityName,"utf-8") line = URLEncoder.encod

苏州公交线路api 查询公交详细信息

苏州公交线路api-苏州公交状态实时跟踪,查询公交详细信息. 接口名称:苏州公交线路api 接口平台:api接口 接口地址:http://apis.juhe.cn/szbusline/bus 支持格式:JSON/XML 请求方式:GET 请求示例:http://apis.juhe.cn/szbusline/bus?key=您申请的APPKEY&bus=11 苏州公交线路api调用代码JSON返回示例: { "resultcode":"200", "

全国公交线路导航

全国公交线路导航:可以查询到全国哪个城市的公交站点,线路,乘线路程等一系列信息! 详情参见;http://www.haoservice.com/docs/23 示例演示: { "error_code":0, "reason":"Success", "result":{ "busstops":[{ "adcode":320506, "citycode":"05