题目涉及算法:

  • 计数问题:枚举;
  • 表达式求值:栈;
  • 小朋友的数字:动态规划;
  • 车站分级:最长路。

计数问题

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

因为数据量不大,所以直接枚举一下每个数,然后统计一下x出现的次数就可以了。

实现代码如下:

#include <bits/stdc++.h>
using namespace std;
int n, x, cnt;
int main() {
cin >> n >> x;
for (int i = 1; i <= n; i ++) {
int j = i;
while (j > 0) {
if (j % 10 == x) cnt ++;
j /= 10;
}
}
cout << cnt << endl;
return 0;
}

表达式求值

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

涉及栈前缀表达式转后缀表达式。

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

小朋友的数字

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

首先表示一下这道题目的题目意思真的好难看懂啊。

因为这句话:

“第一个小朋友的分数是他的特征值,其它小朋友的分数为排在他前面的所有小朋友中(不包括他本人),小朋友分数加上其特征值的最大值。”

到底这个 “其特征值” 是这个小朋友还是排在他前面的所有小朋友。一直没搞清楚啊~。

然后这是一道动态规划的题目。

首先需要求状态 \(f[i]\) ,它表示以 \(a[i]\) 结尾(且不需包含 \(a[i]\))的最大字段和,状态转移方程为:

\(f[i] = max(f[i-1],0) + a[i]\)

这一步操作我觉得是没有问题的。

但是题目没有看懂,所以我决定暂时先不错了~。嗯,就是这么任性。

车站分级

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

这道题目只需要建图+求最长路就可以了。

对于每一趟车,我们假设它的区间范围为 \([L,R]\) ,然后我们假设 \([L,R]\) 范围内的数分为两个集合:

  • 停靠的站对应的数的集合 \(S1\);
  • 没有停靠的站对应的数的集合 \(S2\);

我们知道没有停靠的站的优先级比停靠的站的肯定要低,所以对于每一趟车来说,我们从 \(S2\) 集合中的所有点向 \(S1\) 集合中的所有点连一条权值为 \(1\) 的边。

然后我们设一个起点 \(start\) , 对于所有入度为 0 的点,我们从起点连一条权值为 \(1\) 的点到这些点。

并且这个图是保证不存在环的。

然后我们直接套 SPFA 求一下最长路即可。

实现代码如下:

#include <bits/stdc++.h>
using namespace std;
const int maxn = 1010;
vector<int> g[maxn];
bool bg[maxn][maxn], d[maxn], vis[maxn];
int n, m, cnt, a[maxn], dist[maxn], ans;
queue<int> que;
void test() {
puts("[test]");
for (int i = 1; i <= n; i ++)
printf("\tdist[%2d] = %4d\n", i, dist[i]);
}
int main() {
scanf("%d%d", &n, &m);
while (m --) {
scanf("%d", &cnt);
for (int i = 0; i < cnt; i ++) scanf("%d", &a[i]);
for (int i = a[0], j = 0; i <= a[cnt-1]; i ++) {
if (a[j] == i) j ++;
else {
for (int k = 0; k < cnt; k ++)
bg[i][ a[k] ] = true;
}
}
}
for (int i = 1; i <= n; i ++) {
for (int j = 1; j <= n; j ++) {
if (bg[i][j]) {
g[i].push_back(j);
d[j] = true;
}
}
}
for (int i = 1; i <= n; i ++) {
if (!d[i]) {
dist[i] = 1;
que.push(i);
}
else dist[i] = -1;
}
while (!que.empty()) {
int u = que.front(); que.pop();
vis[u] = false;
int sz = g[u].size();
for (int i = 0; i < sz; i ++) {
int v = g[u][i];
if (dist[v] == -1 || dist[v] < dist[u] + 1) {
dist[v] = dist[u] + 1;
if (!vis[v]) {
vis[v] = true;
que.push(v);
}
}
}
}
for (int i = 1; i <= n; i ++) ans = max(ans, dist[i]);
printf("%d\n", ans);
return 0;
}

作者:zifeiy

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

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

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

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

    题目涉及算法: 成绩:入门题: 图书管理员:模拟: 棋盘:最短路/广搜: 跳房子:RMQ/二分答案/DP(本人解法). 成绩 题目链接:https://www.luogu.org/problemnew ...

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

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

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

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

  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. 关于本地文件请求json文件

    因为需要用到json数据格式,上网查了一下例子之后我就想本地测试一下看能不能成功. 结果,chrome下没有任何反应,打开控制台之后报错如下: XMLHttpRequest cannot load f ...

  2. 阿里云 EMAS HTTPDNS 联合函数计算重磅推出 SDNS 服务,三大能力获得突破

    1. 什么是 HTTPDNS ? 传统的 DNS(Domain Name System)使开发者常面临着域名劫持.调度不精准的问题. HTTPDNS 使用 HTTP 协议替换常用的 UDP 协议,完成 ...

  3. 大数据ETL详解

    ETL是BI项目最重要的一个环节,通常情况下ETL会花掉整个项目的1/3的时间,ETL设计的好坏直接关接到BI项目的成败.ETL也是一个长期的过程,只有不断的发现问题并解决问题,才能使ETL运行效率更 ...

  4. 【JZOJ3853】【NOIP2014八校联考第2场第2试9.28】帮助Bsny(help)

    EVRT Bsny的书架乱成一团了,帮他一下吧! 他的书架上一共有n本书,我们定义混乱值是连续相同高度书本的段数.例如,如果书的高度是30,30,31,31,32,那么混乱值为3:30,32,32,3 ...

  5. 大数据技术之Hadoop(HDFS)

    第1章 HDFS概述 1.1 HDFS产出背景及定义 1.2 HDFS优缺点 1.3 HDFS组成架构 1.4 HDFS文件块大小(面试重点) 第2章 HDFS的Shell操作(开发重点) 1.基本语 ...

  6. java 使用 POI 操作 XWPFDocumen 创建和读取 Office Word 文档基础篇

    注:有不正确的地方还望大神能够指出,抱拳了 老铁! 参考 API:http://poi.apache.org/apidocs/org/apache/poi/xwpf/usermodel/XWPFDoc ...

  7. 基于matlab的傅里叶变换

    原文出处https://blog.csdn.net/qq_37366291/article/details/79832886 例子1 作用:使用傅里叶变换找出隐藏在噪声中的信号的频率成分.(指定信号的 ...

  8. Mysql里查询字段为Json格式的数据模糊查询以及分页方法

    public void datagrid(CustomFormEntity customForm,HttpServletRequest request, HttpServletResponse res ...

  9. python中defaultdict类

    回宿舍前翻翻Codeforces的时候发现了一个有趣的代码..其实是我没这么用过 :D 这是一份417B的代码 import sys from collections import defaultdi ...

  10. Java练习 SDUT-2444_正方形

    正方形 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 给出四个点,判断这四个点能否构成一个正方形. Input 输入的 ...