题目涉及算法:

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

计数问题

题目链接: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. java贪吃蛇小游戏详解

    https://blog.csdn.net/u011622021/article/details/81162083

  2. 编码之Base64编码

    Base64编码 是一种基于 64 个可打印字符来表示二进制数据的方法.目前 Base64 已经成为网络上常见的传输 8 位二进制字节代码的编码方式之一. 为什么会有 Base64 编码呢?因为有些网 ...

  3. 关于父组件通过v-on接收子组件多个参数的一点研究

    写组件的时候遇到一个需求,我需要在子组件向父组件传递信息 this.$emit('myEvent', 信息1, 信息2) 在父组件使用v-on来接收 <my-component @myEvent ...

  4. MaxCompute推出面向开发者的专属版本,普惠大数据开发者

    3月20号,阿里云正式对外宣布推出MaxCompute产品的新规格-开发者版.MaxCompute开发者版是阿里云大数据计算服务发布的开发者专属版本.区别于原有的按量付费.按CU预付费规格,开发者版是 ...

  5. Subsets 集合子集 回溯

    Given a set of distinct integers, S, return all possible subsets. Note: Elements in a subset must be ...

  6. LintCode_67 二叉树中序遍历

    题目 给出一棵二叉树,返回其中序遍历 C++ 非递归 vector<int> inorderTraversal(TreeNode *root) { // write your code h ...

  7. LintCode_408 二进制求和

    给定两个二进制字符串,返回他们的和(用二进制表示). 思路 string s = ""; 目标字符串 cp 存储进位;取 0或1 sum = a[i] + b[i] + cp;分为 ...

  8. spring security四种实现方式

    spring security四种实现方式 spring(20) > 目录(?)[+] 最简单配置spring-securityxml实现1 实现UserDetailsService 实现动态过 ...

  9. JavaScript--淘宝图片切换

    css样式有点问题,但是主要是js逻辑: <!DOCTYPE html> <html> <head> <meta charset="utf-8&qu ...

  10. chrome://inspect调试html页面空白,DOM无法加载的解决方案

    chrome://inspect调试html页面空白,DOM无法加载的解决方案 先描述一下问题 有一段时间没碰huilder hybird app 开发了,今天调试的时候 chrome://inspe ...