任务说明:递推,层层递进,由基础推向顶层。二分不仅可以用来查找数据,还可以确定最合适的值。

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月)的更多相关文章

  1. 【Luogu】【关卡2-9】带有技巧的搜索(2017年10月)

    任务说明:这里的搜索不仅包含了dfs和bfs,还包括剪枝.记录等技巧以加快速度. [USACO06FEB]数字三角形Backward Digit Su… 滑雪 吃奶酪 靶形数独 P1118 [USAC ...

  2. Luogu T7152 细胞(递推,矩阵乘法,快速幂)

    Luogu T7152 细胞(递推,矩阵乘法,快速幂) Description 小 X 在上完生物课后对细胞的分裂产生了浓厚的兴趣.于是他决定做实验并 观察细胞分裂的规律. 他选取了一种特别的细胞,每 ...

  3. NOIP2013提高问题求解T2(关于递推与递归)

    同步发表于我的洛谷博客. NOIP2013提高问题求解2: 现有一只青蛙,初始时在n号荷叶上.当它某一时刻在k号荷叶上时,下一时刻将等概率地随机跳到1,2,--,k号荷叶之一上,直到跳到第1号荷叶为止 ...

  4. 从一道NOI练习题说递推和递归

    一.递推: 所谓递推,简单理解就是推导数列的通项公式.先举一个简单的例子(另一个NOI练习题,但不是这次要解的问题): 楼梯有n(100 > n > 0)阶台阶,上楼时可以一步上1阶,也可 ...

  5. luogu 1291 概率期望递推

    非常好的递推 公式啥的懒得写了,直接放链接哈哈哈https://www.luogu.org/problemnew/solution/P1291 #include<bits/stdc++.h> ...

  6. Codeforces1065G Fibonacci Suffix 【递推】【二分答案】

    题目分析: 首先为了简便起见我们把前$15$的答案找出来,免得我们还要特判$200$以内之类的麻烦事. 然后我们从$16$开始递推.考虑猜测第i位是$0$还是$1$(这本质上是个二分).一开始先猜是$ ...

  7. 【Luogu】【关卡2-15】动态规划的背包问题(2017年10月)【还差一道题】

    任务说明:这是最基础的动态规划.不过如果是第一次接触会有些难以理解.加油闯过这个坎. 01背包二维数组优化成滚动数组的时候有坑有坑有坑!!!必须要downto,downto,downto 情景和代码见 ...

  8. 0x02 递推与递归

    [例题]CH0301 递归实现指数型枚举 #include <iostream> #include <cstdio> #include <algorithm> #i ...

  9. 【Luogu】【关卡2-14】 树形数据结构(2017年10月)【AK】

    任务说明:由一个根节点分叉,越分越多,就成了树.树可以表示数据之间的从属关系 P1087 FBI树 给一个01字符串,0对应B,1对应I,F对应既有0子节点又有1子节点的根节点,输出这棵树的后序遍历. ...

随机推荐

  1. mysql基于GTIDS复制

    GTIDS的环境:一台master 192.168.200.111多个slave: 192.168.200.112 192.168.200.113 修改master服务器:[root@localhos ...

  2. RxJava总结(原)

    1.RxJava的作用 RxJava is a Java VM implementation of Reactive Extensions: a library for composing async ...

  3. jquey弹出框demo

    默认 $('#btn-01').click(function(){ $.dialog({ contentHtml : '<p>我是默认弹出对话框示例展示.我只是用来占位的内容展示,仅仅用来 ...

  4. Python3.5-20190508-廖老师-自我笔记-迭代器

    可以实现for ...in 的都可以称为,可迭代对象,Iterable 可以使用isinstance(是什么实例嘛)来判断是不是可迭代对象 可以被next()函数调用并不断返回下一个值的对象称为迭代器 ...

  5. 【集群】Redis集群设计原理

    Redis集群设计包括2部分:哈希Slot和节点主从 节点主从: 主从设计不算什么新鲜玩意,在数据库中我们也经常用主从来做读写分离,直接上图: 图上能看得到的信息: 1, 只有1个Master,可以有 ...

  6. 【软工项目Beta阶段】绝不划水队OUC-Market版本测试报告

    我们在开发APP的时候进行了软件的测试,同时发现了一些BUG,如下: bug 我的:与各种页面之间的交互不灵活 登录与注册:记住密码功能不完善 商场主界面:搜索功能还没有完善 收藏功能:与数据库的交互 ...

  7. 浏览器 url 编码

    1.问题的由来 : http://www.ruanyifeng.com/blog/2010/02/url_encoding.html 2.网络标准RFC 1738做了硬性规定: 只有字母和数字[0-9 ...

  8. %d format: a number is required, not str。

    python代码: attr_sql = "INSERT INTO `ym_attribute` (`attr_name`, `type_id`, `attr_value`, `attr_s ...

  9. 导入csv 到mysql数据库

    1.查询导入数据存放位置 show variables like '%secure%'; +--------------------------+-----------------------+ | ...

  10. (10)C++ 使用类

    一.运算符重载 1. #include<iostream> using namespace std; class Sum { int add; public: Sum(int add) { ...