10-19 dp专练
dp专练,终于克服了一次自己对dp的恐惧,磕出来一道题。
得分情况:
T1:0
T2:0
T3:0
emmmm,磕出来的题是T2,但是因为初始化和int long long的原因爆零了
T1:n只狼排成一排,每个狼的攻击力分a,b两种,当消灭第i只狼时,需要付出的代价是ai+左右两只狼的b攻击力,消灭i后第i+1和i-1只狼会重新排在一起(如果有的话),求消灭n指只狼的最小代价
很简单的一道区间dp,但是当时我想这个消灭的顺序不一样代价也不一样,所以没想区间dp,直接开始想T2了。
正解:dp[i][j]表示消灭i~j的最小代价,有状态转移方程dp[i][j]=b[i-1]+b[j+1]+min{dp[i][k-1]+dp[k+1][j]};
最后在加上所有的a就行了
T2:求一个正整数N用斐波那契数列中的数不重复表示的方案数。
首先我们要把n分解为斐波拉契数的和,这里用贪心最大分解即可。保存的是斐波拉契数列的序列号。 比如9就分解为1,8序列号为1,5 然后我们注意到其实序列号n,n+1和n+2的分解是一样的,用二进制表示就是110和
001是一样的。 接着我们可以看到,比如1000000这里表示的是数字21贪心后用二进制表示的分解方案,那么他不同的分解方案就有 0110000 0101100 0101011 这里我们看到有三种方案,可以看出在100变成011的方
案的时候,能够使得起始1后面的0都能有变成1的情况,即被选中的情况。 题意要求是用不同的斐波拉契数组合相加,那么如果n的方案为100000000010000000....000001000000这样的时候,随着第一个1的分解,最
终会覆盖到下一个1,这样就不符合题意了切重复统计了。 这样也给dp算法带来了条件。 令dp[i][1]为第i个斐波拉契数列被选中的情况 dp[i][0]则是未被选中。 可知dp[i][1]=dp[i-1][0]+dp[i-1][1]; 那么 dp[i][0]就要分两种情
况了 如果i-1还被选中,那么能给1一直下放为011的空间就只有INDEX[i]-INDEX[i-1]-1的空间了,不然覆盖到了i-1就是重复统计了,如果i-1不被选中就是p[i]-p[i-1]的空间了。 可以知道有多少连续的0的空间k就
有k/2种分解方案。 这样就可以写出方程
dp[i][1]=dp[i-1][0]+dp[i-1][1];
dp[i][0]=(p[i]-p[i-1])/2*dp[i-1][0]+(p[i]-p[i-1]-1)/2*dp[i-1][1];
最后!多组数据一定要初始化!!!数据范围大的记得用long long!!!!!!
#include<iostream>
#include<algorithm>
#include<cmath>
#include<cstring>
#include<ctime>
#define LL long long
using namespace std; LL fe[],p[],f[][];
LL m=,T,n; int main(){
freopen("fibonacci.in","r",stdin);
freopen("fibonacci.out","w",stdout); cin>>T;
while(T --> ){
memset(f,,sizeof(f));
memset(p,,sizeof(p));
memset(fe,,sizeof(fe));
scanf("%lld",&n);
fe[]=; fe[]=;
for(int i=;;i++){
fe[i]=fe[i-]+fe[i-];
if(fe[i]>=n){
m=i;break;
}
}
for(int i=m;i>;i--){
if(n>=fe[i]){
n-=fe[i];
p[++p[]]=i;
}
}
sort(p+,p+p[]+);
f[][]=;f[][]=(p[]-)/;
for(int i=;i<=p[];i++){
f[i][]=f[i-][]+f[i-][];
f[i][]=f[i-][]*((p[i]-p[i-]-)/)+f[i-][]*((p[i]-p[i-])/);
}
printf("%lld\n",f[p[]][]+f[p[]][]);
} fclose(stdin);fclose(stdout);
return ;
}
T3:给定n重循环,每重循环的循环变量为前n个小写字母,给定每重循环的上界和下界,其可能是一个数字,也可能是一个循环变量,但是上界和下界只有可能出现一个循环变量,循环最里面写有cnt++,刚开始cnt=0求cnt最后的值
每重循环的上下界至多出现一个之前的字母,所以我们可以考虑把每个字母连向它这层循环上下界所出现的字母(如果上下界没有字母,就连向一个0号节点)。这样形成的就是一个树结构,并且子树之间的循环是独立的,可以用乘法把它们之间的循环次数连接起来。 设g(u,x)表示字母u取值为x时,u的子树的循环次数。再设f(u,x)为g(u,x)的前缀和。求g(u,x)时,考虑u取值为
10-19 dp专练的更多相关文章
- dp专练
dp练习. codevs 1048 石子归并 区间dp #include<cstdio> #include<algorithm> #include<cstring> ...
- 记502 dp专练
趁着503的清早 我还算清醒把昨天老师讲的内容总结一下,昨天有点迷了 至使我A的几道题都迷迷糊糊的.(可能是我太菜了) 这道题显然是 数字三角形的变形 好没有经过认真思考然后直接暴力了 这是很不应该的 ...
- DP 专练
A - 跳蚤电话 观察性质,可以发现每次连边的点一定是有祖先关系的,可以直接挂上去一个,也可以是在中间边上插入一个点. 所以我很自然的想到去计算树上的点的加入顺序,因为一但加入顺序确定,每一次的操作也 ...
- 背水一战 Windows 10 (19) - 绑定: TemplateBinding 绑定, 与 RelativeSource 绑定, 与 StaticResource 绑定
[源码下载] 背水一战 Windows 10 (19) - 绑定: TemplateBinding 绑定, 与 RelativeSource 绑定, 与 StaticResource 绑定 作者:we ...
- Scrum会议10.19
Scrum会议 组名称:好好学习 项目名称:记账本 参会成员:林莉(Master)胡丽娜 宫丽君 汪东涵 时间:2016.10.19 已完成内容: 1.完成新项目的查找,查找学姐的代码和项目. 2.理 ...
- IDC Digital Transition Annual Festival(2018.10.19)
时间:2018.10.19地点:北京万达文化酒店
- 2018.10.19浪在ACM 集训队第一次测试赛
2018.10.19浪在ACM 集训队第一次测试赛 待参考资料: [1]:https://blog.csdn.net/XLno_name/article/details/78559973?utm_so ...
- 20172319 2018.10.19《Java程序设计教程》第7周课堂实践(补写博客)
20172319 2018.10.19 <Java程序设计教程>第7周课堂实践 课程:<程序设计与数据结构> 班级:1723 学生:唐才铭 学号:20172319 指导老师:王 ...
- P1251 递推专练3
递推专练3 描述 Description 圆周上有N个点.连接任意多条(可能是0条)不相交的弦(共用端点也算相交)共有多少种方案? 输入格式 Input Format 读入一个数N.<=N< ...
随机推荐
- JDK安装和环境变量配置-成功经验
JDK安装和环境变量配置1.下载安装软件 2.安装JDK--开发环境,路径 3.之后打开安装路径下的bin文件夹路径,我的是默认安装C:\Program Files\Java\jdk1.6.0_10\ ...
- 《利用Python进行数据分析》笔记---第5章pandas入门
写在前面的话: 实例中的所有数据都是在GitHub上下载的,打包下载即可. 地址是:http://github.com/pydata/pydata-book 还有一定要说明的: 我使用的是Python ...
- C语言基础:常见循环语句 分类: iOS学习 c语言基础 2015-06-10 21:46 13人阅读 评论(0) 收藏
for语句 for( 初始化表达式; 循环判断条件 ;增量表达式); while(条件表达式){ 循环体; } 先判断条件表达式,如果为真就执行循环体,执行完再去判断条件表达式 do{ 循环体; } ...
- proxool配置及测试(数据库用的MySQL)
Proxool连接池设置 Proxool连接池是sourceforge下的一个开源项目,这个项目提供一个健壮.易用的连接池,最为关键的是这个连接池提供监控的功能,方便易用,便于发现连接泄漏的情况. ...
- vue components
https://github.com/vuejs/awesome-vue#components--libraries
- test20190324 树
题意 树(tree.cpp/c/pas) [题目背景] 这道题标算在评测机上的时间约为自己电脑的2/3 [问题描述] [输入格式] 共 n+2 行.第 1 行 1 个数,n. 后面 2-n 行,每行两 ...
- div+css 怎么让一个小div在另一个大div里面 垂直居中
div+css 怎么让一个小div在另一个大div里面 垂直居中 方法1: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 .parent { width:800 ...
- Nginx隐藏主机信息,proxy_hide_header 与fastcgi_hide_header
Nginx中proxy_hide_header 与fastcgi_hide_header都可以隐藏主机头信息,两者在具体使用时还是有着一定的区别的.刚好业务使用的nginx反向代理在显示响应头时将后端 ...
- Oracle根据表的大小排序SQL语句
--按照数据行数排序select table_name,blocks,num_rows from dba_tables where owner not like '%SYS%' and table_n ...
- Word中回车和网页换行替换
回车^p 换行^l 用编辑中的查找替换即可 查找^l,替换为^p (一)有建议说按Delete键一个一个将其删除,这是麻烦的,其实可用WORD的查找替换工具一次性替换成回车符.查找--点特殊字符--手 ...