题目链接:http://soj.me/1211
Description

Bruce是K国的商人,他在A州成立了自己的公司,这次他的公司生产出了一批性能很好的产品,准备宣传活动开始后的第L天到达B州进行新品拍卖,期间Bruce打算将产品拿到各个州去做推销宣传,以增加其影响力。

K国有很多个州,每个州都与其他一些州相邻,但是K国对商人作宣传却有一些很奇怪的规定:
1、 商人只能从某些州到达另外一些州,即连通路线是单向的,而且有些州可能是到达不了的。
2、 商人不允许在同一个州连续宣传两天或以上,每天宣传完必须离开该州。
3、 商人可以多次来到同一个州进行宣传。

"我必须找出一条影响力最大的路线才行",Bruce想,"但我首先必须知道到底有多少这种符合规定的宣传路线可供我选择。"现在Bruce把任务交给了你。并且出于考虑以后的需要,你还要帮他算出给出的两州之间的路线的总数。

Input
输入文件第一行包含三个整数n,m,L(1≤n,L≤100),分别表示K国的州数、连通路线的数量,以及多少天后必须到达B州。接下来有m行,每行一队整数x,y(1≤x,y≤n),表示商人能从x州到达y州。
第m+2行为一个整数q(1≤q≤100),表示Bruce有q个询问。下面q行每行两个整数A,B(1≤A,B≤n),即A、B州的位置。
Output
输出文件包含q行,每行一个整数t,为所求的从A州到B州满足上述规定的路线总数。
输入数据中的询问将保证答案t在长整数范围内,即t<231
Sample Input
aaarticlea/jpeg;base64,/9j/4AAQSkZJRgABAQEAYABgAAD/2wBDAAgGBgcGBQgHBwcJCQgKDBQNDAsLDBkSEw8UHRofHh0aHBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAARABIDASIAAhEBAxEB/8QAGAABAAMBAAAAAAAAAAAAAAAAAAMFBwT/xAAlEAACAQQCAQMFAAAAAAAAAAABAgMABAURBiESIjFBMjZxdbP/xAAYAQACAwAAAAAAAAAAAAAAAAAAAwEEBf/EABsRAQEAAgMBAAAAAAAAAAAAAAEAAgMEEyFh/9oADAMBAAIRAxEAPwDQeRW+SyVnctBIkiiScOk87qm0ciP0aZWA8dkEDZA2fcGPCWPI+PXkUt3GIcQjkyQxTGdtMrAhUVQO5CraVd/UB1pa7cnHmbaW5hjxEktoZJJGulnjChWYsT4lvLoHvr3B1vommvuQYaSe/jGSxrW9yXEiCWIiTe9eWohvs/LH8n5ocDh9jlnsER+zt+9wDE9G0uKWO4hSaGRJIpFDI6MCrKewQR7ilVfFPs7B/r4P5rStB8ZJW9KUqIlKUoi//9k=" alt="" /> Copy sample input to clipboard
4 5 6
1 2
2 3
3 4
4 1
2 4
2
1 4
4 2
Sample Output
2
1

Problem Source: ZSUACM Team Member

思路:

  一开始看到这道题觉得应该是用深搜来写,因为N<=100,觉得规模并不大,没想到提交之后却超时了,后来想了想每次深搜需要的时间复杂度位O(n^3),可是要查询Q次,Q<=100,所以整个算法的时间复杂度位O(n^4),超时也就不奇怪了。

  接着用动态规划做这道题,想了想,状态转移方程是:f[a][b][l] = ∑ f[c][b][l-1],其中c为a可以用一天到达的州(即有一条从a到c的路)。转移方程的意思是:如果从c州到b州可以在"l-1"天之内完成,那么从a州到b州可以在"l"天之内完成。

我的代码:

 #include <iostream>
#include <cstring>
#include <vector>
using namespace std; const int MAX = ;
int n, m, l, q;
int start, end;
vector<int> rodes[MAX]; //用来记录路
int dp[MAX][MAX][MAX]; void findWays() {
for (int k = ; k <= l; k++) { //从2天开始找
for (int i = ; i <= n; i++) {
int len = rodes[i].size();
for (int j = ; j <= n; j++) {
for (int x = ; x < len; x++) { //rodes[i].at((x) 即为i州可以一天之内到达的州
dp[i][j][k] += dp[rodes[i].at(x)][j][k-]; //状态转移方程
//cout << i << ' ' << j << ' ' << k << ' ' << dp[i][j][k] << endl;;
}
}
}
}
} int main() {
cin >> n >> m >> l;
memset(dp, , sizeof(dp)); //dp全部初始化为0
int a, b;
for (int i = ; i < m; i++) {
cin >> a >> b;
rodes[a].push_back(b); //在a州添加一条到b州的路
dp[a][b][] = ;        //从a到b在一天内的走法为一种
}
findWays();
cin >> q;
for (int i = ; i < q; i++) {
cin >> start >> end;
cout << dp[start][end][l] << endl;
}
return ;
}

另一种思路:

  只是另一种代码的思路,上述代码中的空间复杂度有些大,所以考虑到可以用斐波那契数列的思路考虑,所以可以将MATRIX[A][B][L],转化为三个MATRIX[A][B]进行状态转移,即第一个矩阵存L=1时的路径数,第二个矩阵存L=i-1(2 <= i <= m)时的路径数,第三个矩阵存L=i时的路径数,这样大大节省了内存占有。

代码如下:

 #include <iostream>
#include <cstring>
using namespace std; const int MAX = ; int matrix_one[MAX][MAX];
int matrix_two[MAX][MAX];
int matrix_three[MAX][MAX]; int main() {
int n, m, l, q;
int start, end;
int a, b;
cin >> n >> m >> l;
memset(matrix_one, , sizeof(matrix_one)); //现将前两格矩阵初始化为0,即无路
memset(matrix_two, , sizeof(matrix_two));
for (int i = ; i < m; i++) {
cin >> a >> b;
matrix_one[a][b]++; //每增加一条路,从a到b的路径数加一 即位L=1时的路径数矩阵
matrix_two[a][b]++; //第二个矩阵也记录L=1时的情况 从而推倒出之后的矩阵
}
for (int x = ; x <= l; x++) { //L从2开始
memset(matrix_three, , sizeof(matrix_three));
for (int i = ; i <= n; i++) {
for (int j = ; j <= n; j++) {
for (int k = ; k <= n; k++) {
matrix_three[i][j] += matrix_one[i][k] * matrix_two[k][j];
}
}
}
/* 将第三个矩阵的值给第二个矩阵 */
memcpy(matrix_two, matrix_three, sizeof(matrix_one));
}
cin >> q;
while (q--) {
cin >> start >> end;
cout << matrix_three[start][end] << endl;
}
return ;
}

两种思路各有各的优势,第一种速度快一些,第二种内存占用少一些,下图(第一行为第二种,第二行第一种):

其实差不多啦 能ac就好。

Sicily 1211. 商人的宣传的更多相关文章

  1. [SOJ] 商人的宣传

    Description Bruce是K国的商人,他在A州成立了自己的公司,这次他的公司生产出了一批性能很好的产品,准备宣传活动开始后的第L天到达B州进行新品拍卖,期间Bruce打算将产品拿到各个州去做 ...

  2. sicily 题目分类

    为了方便刷题,直接把分类保存下来方便来找. 转自:http://dengbaoleng.iteye.com/blog/1505083 [数据结构/图论] 1310Right-HeavyTree笛卡尔树 ...

  3. [原创]webapp/css3实战,制作一个《炉石传说》宣传页

    在移动网页,尤其是webapp中常需要用到大量的css3动画,来获得良好交互体验 我之前帮朋友做了一个,可惜没帮上忙现在和大家分享一下 目标是要做一个<炉石传说>游戏的介绍宣传页面,文字内 ...

  4. sicily 中缀表达式转后缀表达式

    题目描述 将中缀表达式(infix expression)转换为后缀表达式(postfix expression).假设中缀表达式中的操作数均以单个英文字母表示,且其中只包含左括号'(',右括号‘)’ ...

  5. PMD宣传文案

    队名:Clover 李烈争 031402614 林昊斌 031402615 李坤隆 031402612 林瑞斌 031402617 解宇虹 031402338 林 锦 031402339 目录 一. ...

  6. sicily 1934. 移动小球

    Description 你有一些小球,从左到右依次编号为1,2,3,...,n. 你可以执行两种指令(1或者2).其中, 1 X Y表示把小球X移动到小球Y的左边, 2 X Y表示把小球X移动到小球Y ...

  7. IT小喇叭-企业品牌宣传、产品营销推广的首选

    IT小喇叭-企业品牌宣传.产品营销推广的首选 IT小喇叭,成立于2015年6月初,成都芮嘉科技有限公司旗下产品,主要进行媒体资源整合.宣传报道:使移动互联网等相关企业的产品宣传.品牌营销变得更加方便. ...

  8. 三星s4宣传片配色有惊喜

    三星s4宣传片配色有惊喜据了解,一周前,三星曾对外发布了新旗舰手机galaxy s4的宣传视频,不过那份视频里所含信息仅仅只有s4发布会的邀请函.而日前,三星官方发布了s4的第二弹宣传片则暗示该机在配 ...

  9. 商人过河问题(DFS)

    问题描述:3个商人带着3个仆人过河,过河的工具只有一艘小船,只能同时载两个人过河,包括划船的人.在河的任何一边,只要仆人的数量超过商人的数量,仆人就会联合起来将商人杀死并抢夺其财物,问商人应如何设计过 ...

随机推荐

  1. Java的StringBuIlder扩容机制

    JDK 1.6中,扩容的源码是这样: void expandCapacity(int minimumCapacity) { int newCapacity = (value.length + 1) * ...

  2. forEach遍历数组对象且去重

    forEach遍历数组对象 var obj1 = [{ key: '01', value: '哈哈' }, { key: '02', value: '旺旺' }, { key: '03', value ...

  3. C++模式学习------工厂模式

    工厂模式属于创建型模式,大致可以分为简单工厂模式.抽象工厂模式. 简单工厂模式,它的主要特点是需要在工厂类中做判断,从而创造相应的产品. enum PTYPE { ProdA = , ProdB = ...

  4. 【转】一口气读懂NB-IoT

    在过去的一年多,NB-IoT真的可以说是大红大紫.在通信圈里,除了说5G,就是说物联网.如果说物联网,八成就是在说NB-IoT. 在目前5G还没来的情况下,NB-IoT基本上是独领风骚.风光无限. 各 ...

  5. kafka问题集(二):__consumer_offsets topic的分区中有一个分区数据很多,多达1T

    仅个人实践中所遇到的问题,若有不对的,欢迎交流! 一.场景描述 kafka集群中有几台突然挂了,后台日志显示设备空间满了,消息无法写入__consumer_offsets topic的分区中了.查看k ...

  6. 【codeforces 553E】 Kyoya and Train

    http://codeforces.com/problemset/problem/553/E (题目链接) 艹尼玛,CF还卡劳资常数w(゚Д゚)w!!系统complex被卡TLE了T_T,劳资写了一天 ...

  7. 解题:SDOI 2014 数表

    题面 为了好写式子,先不管$a$的限制 设$facs$为因子和,那么有 $ans=\sum\limits_{i=1}^n\sum\limits_{j=1}^mfacs(gcd(i,j))$ 再设$f( ...

  8. 配置iOS项目的设备系统目标设置:Base SDK和Deployment Target

    配置iOS项目的设备系统目标设置:Base SDK和Deployment Target Xcode为开发者提供了两个可配置的设置:第一个是Base SDK,第二个是iOS的Deployment Tar ...

  9. mysql 优化总结

    1.对查询进行优化,要尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. (laravel 可以使用 debugbar 包,可以及时发现低效 sql 语句,不使用索 ...

  10. Chapter 4(栈与队列)

    1.栈的顺序存储结构 //*********************************stack_array.h************************************ #ifn ...