【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子节点的根节点,输出这棵树的后序遍历. ...
随机推荐
- 2019-10-31-WPF-等距布局
title author date CreateTime categories WPF 等距布局 lindexi 2019-10-31 9:0:2 +0800 2018-2-21 17:3:4 +08 ...
- 团队作业-Bata冲刺第一天
这个作业属于哪个课程 https://edu.cnblogs.com/campus/xnsy/SoftwareEngineeringClass2 这个作业要求在哪里 https://edu.cnblo ...
- 扩展阿里巴巴Java开发规约插件(转)
转自:https://blog.csdn.net/u014513883/article/details/79186893 1.前言 工作中难免会遇到维护别人代码的情况,那么首先就得看懂别人写的代码.如 ...
- 使用CSS3的@media来编写响应式的页面
首先要知道,我们为什么要写自适应的页面(响应式页面) [直接看干货] 众所周知,电脑.平板.手机的屏幕是差距很大的,假如在电脑上写好了一个页面,在电脑上看起来不错,但是如果放到手机上的话,那可能就会乱 ...
- webpack (1)
node_modules/.bin/webpack 用webpack 打包 因为我们没有全局安装webpack 所以要用到这条命令 创建html npm install --save-dev html ...
- Magolor的数据结构作业
\(CodeForces 706E ~Working routine\) 给出一个矩阵,每次操作交换两个子矩阵,求最后状态. 使用链表存储,每次交换后,影响到的之后矩阵边缘的指针,暴力修改. \(~~ ...
- oracle时间问题 与case then
思路一 --select * from nls_session_parameters where parameter='NLS_DATE_LANGUAGE'; -- 修改会话的默认日期格式 ALTER ...
- dosbox下载并配置BC3.1及环境变量的方法
https://www.tuicool.com/articles/v2A3mm--Win8下用DOSBox编写汇编语言 http://www.dosbox.com/ http://www.masm32 ...
- 给元素绑定 class
<div id="app04"> <label v-bind:class="{'Class1':Class1}">sasjadjagd& ...
- HTML-参考手册: 按字母顺序排列
ylbtech-HTML-参考手册: 按字母顺序排列 1.返回顶部 1. 按字母顺序排列 New : HTML5新标签 标签 描述 <!--...--> 定义注释 <!DOCTYPE ...