【Luogu】【关卡2-12】递推与递归二分(2017年10月)
任务说明:递推,层层递进,由基础推向顶层。二分不仅可以用来查找数据,还可以确定最合适的值。
P1192 台阶问题
有N级的台阶,你一开始在底部,每次可以向上迈最多K级台阶(最少1级),问到达第N级台阶有多少种不同方式。
输入文件的仅包含两个正整数N,K。
输入文件stair.out仅包括1个正整数,为不同方式数,由于答案可能很大,你需要输出mod 100003后的结果。
解答: 我自己写的时间复杂度是O(N^2), 空间复杂度是O(K);看了题解还有用前缀和方法O(N)的...真厉害
提交了一次AC了
#include <bits/stdc++.h>
using namespace std;
void print(vector<int> dp, string strName) {
printf("======begin=====debug=====name[%s]======\n", strName.c_str());
for (int i = ; i < dp.size(); ++i) {
printf("%d ", dp[i]);
}
printf("\n");
}
int solve(int n, int k) {
vector<int> dp(n, );
for (int i = ; i < n; ++i) {
if (i < k) { dp[i] = ; }
for (int j = i-; j >= && j >= i - k; --j) {
dp[i] += dp[j];
}
}
//print(dp, "another method");
return dp[n-];
}
//这里时间复杂度是O(N^2), 空间复杂度是O(K);
//看了题解还有用前缀和方法O(N)的...真厉害
int main() {
int n, k;
cin >> n >> k;
vector<int> dp(k, );
int cnt = ;
int idx;
while(cnt <= n) {
idx = (cnt - ) % k;
int summ = ;
//相当于下面两堆..
//本质问题在于:第一遍初始化dp数组的时候,比如n=5, k=3, dp[0] =1,dp[1]=2, dp[2]=4; 其实这不是用所有的加起来,而是只加前面的那堆。
for (int i = ; i < min(cnt, k); ++i) {
summ += dp[i];
summ %= ;
}
/*
if (cnt < k) {
for (int i = 0; i < cnt; ++i) {
summ += dp[i];
}
} else {
for (int i = 0; i < k; ++i) {
summ += dp[i];
}
}
*/
dp[idx] = summ % ;
cnt++;
}
cout << dp[idx] << endl;
//int answer = solve(n, k);
//printf("another slover: %d\n", answer);
return ;
}
数的划分
传球游戏
奇怪的电梯
P1216 [USACO1.5]数字三角形 Number Triangles
没错就是你想的那道题~

解答:
转移方程为:
tri[i][j] = tri[i][j] (i == N-1) //最后一行
tri[i][j] += max(tri[i+1][j], tri[i+1][j+1]) //上面那些行
#include <bits/stdc++.h>
using namespace std;
int main() {
int lines;
cin >> lines;
int tri[lines][lines] = {};
for (int i = ; i < lines; ++i) {
for (int j = ; j < i+; ++j) { //写代码的时候注意下i, j的范围
cin >> tri[i][j];
}
}
for (int i = lines - ; i >= ; --i) {
for (int j = ; j <= i; ++j) {
tri[i][j] += max(tri[i+][j], tri[i+][j+]);
}
}
cout << tri[][] << endl;
return ;
}
数列分段Section II
丢瓶盖
【Luogu】【关卡2-12】递推与递归二分(2017年10月)的更多相关文章
- 【Luogu】【关卡2-9】带有技巧的搜索(2017年10月)
任务说明:这里的搜索不仅包含了dfs和bfs,还包括剪枝.记录等技巧以加快速度. [USACO06FEB]数字三角形Backward Digit Su… 滑雪 吃奶酪 靶形数独 P1118 [USAC ...
- Luogu T7152 细胞(递推,矩阵乘法,快速幂)
Luogu T7152 细胞(递推,矩阵乘法,快速幂) Description 小 X 在上完生物课后对细胞的分裂产生了浓厚的兴趣.于是他决定做实验并 观察细胞分裂的规律. 他选取了一种特别的细胞,每 ...
- NOIP2013提高问题求解T2(关于递推与递归)
同步发表于我的洛谷博客. NOIP2013提高问题求解2: 现有一只青蛙,初始时在n号荷叶上.当它某一时刻在k号荷叶上时,下一时刻将等概率地随机跳到1,2,--,k号荷叶之一上,直到跳到第1号荷叶为止 ...
- 从一道NOI练习题说递推和递归
一.递推: 所谓递推,简单理解就是推导数列的通项公式.先举一个简单的例子(另一个NOI练习题,但不是这次要解的问题): 楼梯有n(100 > n > 0)阶台阶,上楼时可以一步上1阶,也可 ...
- luogu 1291 概率期望递推
非常好的递推 公式啥的懒得写了,直接放链接哈哈哈https://www.luogu.org/problemnew/solution/P1291 #include<bits/stdc++.h> ...
- Codeforces1065G Fibonacci Suffix 【递推】【二分答案】
题目分析: 首先为了简便起见我们把前$15$的答案找出来,免得我们还要特判$200$以内之类的麻烦事. 然后我们从$16$开始递推.考虑猜测第i位是$0$还是$1$(这本质上是个二分).一开始先猜是$ ...
- 【Luogu】【关卡2-15】动态规划的背包问题(2017年10月)【还差一道题】
任务说明:这是最基础的动态规划.不过如果是第一次接触会有些难以理解.加油闯过这个坎. 01背包二维数组优化成滚动数组的时候有坑有坑有坑!!!必须要downto,downto,downto 情景和代码见 ...
- 0x02 递推与递归
[例题]CH0301 递归实现指数型枚举 #include <iostream> #include <cstdio> #include <algorithm> #i ...
- 【Luogu】【关卡2-14】 树形数据结构(2017年10月)【AK】
任务说明:由一个根节点分叉,越分越多,就成了树.树可以表示数据之间的从属关系 P1087 FBI树 给一个01字符串,0对应B,1对应I,F对应既有0子节点又有1子节点的根节点,输出这棵树的后序遍历. ...
随机推荐
- oracle10G rac asm 安装总结
前言 安装步骤是参考三思博主(http://blog.chinaunix.net/uid-22741583-id-177284.html),安装的时候由于概念没搞清楚,急于求成,折腾了两天才顺利装完, ...
- mocha.js
mocha 如果你听说过“测试驱动开发”(TDD:Test-Driven Development),单元测试就不陌生. 单元测试是用来对一个模块.一个函数或者一个类来进行正确性检验的测试工作. 比如对 ...
- SQL的子查询与JOIN的小试牛刀
//学生表CREATE TABLE student( ID INT PRIMARY KEY, s_name ) NOT NULL, class_id INT NOT NULL); , "qf ...
- Python技能树
本博客Python内容的索引,以后就照着它写了.
- mitmproxy 代理介绍及入门
转载请注明出处 https://www.cnblogs.com/majianming/p/11823669.html mitmproxy 是一个python 写成的代理工具,可以代理https.htt ...
- 【Shell】ps -ef 和ps aux
两者没太大差别 追溯到Unix系统中的两种风格,System V风格和BSD 风格,ps aux最初用到Unix Style中,而ps -ef被用在System V Style中,两者输出略有不同.现 ...
- hdu 6092 Rikka with Subset (集合计数,01背包)
Problem Description As we know, Rikka is poor at math. Yuta is worrying about this situation, so he ...
- Java中常用的解决乱码的几种方法
乱码有时候是一个非常让人头疼的问题,这里就总结一下常用的解决乱码的方法. 只知道的用法,却不明白为什么这么用…… 一. 在Java代码中: request.setCharacterEncoding(& ...
- 【Java架构:基础技术】一篇文章搞掂:Idea
一.使用技巧 1.1.配置Maven 打开File-Settings打开设置界面 1.2.配置JDK JDK可以设置默认版本,也可以设置针对某个项目 分别对应File-Other Setting-De ...
- (转)深入剖析Java中的装箱和拆箱
转:https://www.cnblogs.com/dolphin0520/p/3780005.html 深入剖析Java中的装箱和拆箱 自动装箱和拆箱问题是Java中一个老生常谈的问题了,今天我们就 ...