题目涉及算法:

  • 成绩:入门题;
  • 图书管理员:模拟;
  • 棋盘:最短路/广搜;
  • 跳房子:RMQ/二分答案/DP(本人解法)。

成绩

题目链接:https://www.luogu.org/problemnew/show/P3954

入门题,直接计算一下即可。

实现代码如下:

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. int a, b, c;
  4. int main() {
  5. cin >> a >> b >> c;
  6. cout << (a * 2 + b *3 + c * 5) / 10 << endl;
  7. return 0;
  8. }

图书管理员

题目链接:https://www.luogu.org/problem/P3955

基础题目,实现代码如下:

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. bool check(int a, int b, int n) {
  4. int t = 1;
  5. for (int i = 0; i < n; i ++) t *= 10;
  6. return a % t == b % t;
  7. }
  8. int n, m, book[1001], x, y;
  9. int main() {
  10. cin >> n >> m;
  11. for (int i = 0; i < n; i ++) cin >> book[i];
  12. while (m --) {
  13. cin >> x >> y;
  14. int res = -1;
  15. for (int i = 0; i < n; i++) {
  16. if (check(book[i], y , x)) {
  17. if (res == -1) res = book[i];
  18. else res = min(res, book[i]);
  19. }
  20. }
  21. cout << res << endl;
  22. }
  23. return 0;
  24. }

棋盘

题目链接:https://www.luogu.org/problem/P3956

其实我们探索一下1这道问题的本质就是一个迷宫中的最短路,用SPFA可以求解最短路。

这里较为繁琐的就是状态到状态之间的扩展,但是并不难。

实现代码如下:

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. const int maxn = 15010, maxm = 40040;
  4. int n, m, a[maxn], b[maxn], c[maxn], d[maxn], val[maxm], cnt[maxn];
  5. int main() {
  6. scanf("%d%d", &n, &m);
  7. for (int i = 0; i < m; i ++) {
  8. scanf("%d", &val[i]);
  9. cnt[ val[i] ] ++;
  10. }
  11. for (int i = 1; 2+9*i <= n; i ++) {
  12. int tmp = 0;
  13. for (int j = 2+9*i; j <= n; j ++) {
  14. tmp += cnt[j-1-9*i] * cnt[j-1-7*i];
  15. c[j-i] += cnt[j] * tmp;
  16. d[j] += cnt[j-i] * tmp;
  17. }
  18. tmp = 0;
  19. for (int j = n-1-9*i; j >= 1; j --) {
  20. tmp += cnt[j+1+8*i] * cnt[j+1+9*i];
  21. a[j] += cnt[j+2*i] * tmp;
  22. b[j+2*i] += cnt[j] * tmp;
  23. }
  24. }
  25. for (int i = 0; i < m; i ++)
  26. printf("%d %d %d %d\n", a[ val[i] ], b[ val[i] ], c[ val[i] ], d[ val[i] ]);
  27. return 0;
  28. }

跳房子

题目链接:https://www.luogu.org/problem/P3957

这道题目我用到了如下算法:

  • 线段树求区间最大值;
  • 二分答案;
  • DP求每一次枚举答案g时是否能够找到 \(\ge k\) 的解法。

题解地址:https://www.cnblogs.com/codedecision/p/11753024.html

作者:zifeiy

2017年NOIP普及组复赛题解的更多相关文章

  1. 2010年NOIP普及组复赛题解

    题目及涉及的算法: 数字统计:入门题: 接水问题:基础模拟题: 导弹拦截:动态规划.贪心: 三国游戏:贪心.博弈论. 数字统计 题目链接:洛谷 P1179 这道题目是一道基础题. 我们只需要开一个变量 ...

  2. 2016年NOIP普及组复赛题解

    题目涉及算法: 买铅笔:入门题: 回文日期:枚举: 海港:双指针: 魔法阵:数学推理. 买铅笔 题目链接:https://www.luogu.org/problem/P1909 设至少要买 \(num ...

  3. 2014年NOIP普及组复赛题解

    题目涉及算法: 珠心算测验:枚举: 比例简化:枚举: 螺旋矩阵:模拟: 子矩阵:状态压缩/枚举/动态规划 珠心算测验 题目链接:https://www.luogu.org/problem/P2141 ...

  4. 2013年NOIP普及组复赛题解

    题目涉及算法: 计数问题:枚举: 表达式求值:栈: 小朋友的数字:动态规划: 车站分级:最长路. 计数问题 题目链接:https://www.luogu.org/problem/P1980 因为数据量 ...

  5. 2011年NOIP普及组复赛题解

    题目涉及算法: 数字反转:模拟: 统计单词数:模拟: 瑞士轮:模拟/排序: 表达式的值:后缀表达式/DP. 数字反转 题目链接:https://www.luogu.org/problem/P1307 ...

  6. 2008年NOIP普及组复赛题解

    题目涉及算法: ISBN号码:简单字符串模拟: 排座椅:贪心: 传球游戏:动态规划: 立体图:模拟. ISBN号码 题目链接:https://www.luogu.org/problem/P1055 简 ...

  7. 2005年NOIP普及组复赛题解

    题目涉及算法: 陶陶摘苹果:入门题: 校门外的树:简单模拟: 采药:01背包: 循环:模拟.高精度. 陶陶摘苹果 题目链接:https://www.luogu.org/problem/P1046 循环 ...

  8. 2018年NOIP普及组复赛题解

    题目涉及算法: 标题统计:字符串入门题: 龙虎斗:数学题: 摆渡车:动态规划: 对称二叉树:搜索. 标题统计 题目链接:https://www.luogu.org/problem/P5015 这道题目 ...

  9. 2015年NOIP普及组复赛题解

    题目涉及算法: 金币:入门题: 扫雷游戏:入门题: 求和:简单数学推导: 推销员:贪心. 金币 题目链接:https://www.luogu.org/problem/P2669 入门题,直接开一个循环 ...

随机推荐

  1. Ubuntu下安装Mongo方法

    场景:Ubuntu14下安装mongo,建议不要使用apt-get install 的命令安装,因为版本比较老 1.deb下载地址(可以自行选择OS,版本,server或tool或shell)http ...

  2. js 常用事件总结

    无论web端还是手机端,用户的交互总伴随着事件监听 下面是我总结的一些常用到的事件 1.监听标签内容变化 非input元素 $(dom).bind('DOMNodeInserted',function ...

  3. Linux操作系统各版本ISO镜像下载(包括oracle linux\redhat\centos\u

    Linux操作系统各版本ISO镜像下载(包括oracle linux\redhat\centos\ubuntu\debian等) 1.Oracle Linux(下载地址) (1)OracleLinux ...

  4. SQL优化系列(二)- 优化Top SQL

    优化最耗资源的N条SQL语句 如何从SGA或者AWR中找出最消耗资源的SQL, 例如最慢的20条SQL, 然后逐条优化? SQL自动优化工具SQL Tuning Expert Pro for Orac ...

  5. 2018-8-10-win10-UWP-修改密码框文字水平

    title author date CreateTime categories win10 UWP 修改密码框文字水平 lindexi 2018-08-10 19:17:19 +0800 2018-2 ...

  6. MSSQL2008 数据压缩方法

    数据压缩功能使得SOL Server 2008允许在表.索引和分区中执行数据压缩,这样不仅可以节省磁盘空间,而且允许更多数据置入RAM中,从而提升数据库查询的性能. 1.启用行压缩 如果我们要在指定的 ...

  7. php怎么自动加载

    在 PHP 代码的顶部你是不是经常看到这样的代码. require 'lionis.php'; require 'is.php'; require 'cool.php'; 如果只是引入几个 PHP 脚 ...

  8. PHP 中的 curl 函数发送 Post 请求应该注意的几点

    public function http_request( $url, $post = '', $timeout = 5 ){ if( empty( $url ) ){return ;}$ch = c ...

  9. PHP学习(数据类型)

    PHP中,支持8种原始类型,其中包括四种标量类型.两种复合类型和两种特殊类型.PHP是一门松散类型的语言,不必向PHP声明变量的数据类型,PHP会自动把变量转换为自动的数据类型,一定程度降低了学习PH ...

  10. oracle审计实施

    1.语句审计 Audit session;  Audit session By ; 与instance连接的每个会话生成一条审计记录.审计记录将在连接时期插入并且在断开连接时期进行更新. 保留有关会话 ...