题目涉及算法:

  • 数字反转:模拟;
  • 统计单词数:模拟;
  • 瑞士轮:模拟/排序;
  • 表达式的值:后缀表达式/DP。

数字反转

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

这道题目是一道基础的模拟题,只需要模拟将数字进行翻转就可以了,注意 \(0\) 和 负数。

实现代码如下:

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. void solve(int num) {
  4. if (num < 0) { putchar('-'); num = -num; }
  5. if (num == 0) { cout << 0 << endl; return; }
  6. int t = 0;
  7. while (num > 0) {
  8. t = t * 10 + num % 10;
  9. num /= 10;
  10. }
  11. cout << t << endl;
  12. }
  13. int n;
  14. int main() {
  15. cin >> n;
  16. solve(n);
  17. return 0;
  18. }

统计单词数

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

这道题目就是一道简单的字符串匹配问题。

关于字符串匹配问题有一些经典的算法(比如KMP等),但是我们这道题目数据量比驾小所以直接暴力比较就可以了。

需要注意的是字符串的读入( char 数组使用 getsstring 使用 cin.getline

实现代码如下:

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. char s[12], t[1000010];
  4. int n, m, cnt, idx;
  5. int main() {
  6. gets(s); gets(t);
  7. for (n = 0; s[n]; n ++) s[n] = tolower(s[n]);
  8. for (m = 0; t[m]; m ++) t[m] = tolower(t[m]);
  9. for (int i = 0; i+n-1 < m; i ++) {
  10. if ((i+n == m || t[i+n] == ' ') && (i == 0 || t[i-1] == ' ')) {
  11. bool flag = true;
  12. for (int j = 0; j < n; j ++) if (s[j] != t[i+j]) {
  13. flag = false;
  14. break;
  15. }
  16. if (flag) {
  17. cnt ++;
  18. if (cnt == 1) idx = i;
  19. }
  20. }
  21. }
  22. if (cnt) printf("%d %d\n", cnt, idx);
  23. else puts("-1");
  24. return 0;
  25. }

瑞士轮

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

这道题目就是按照题目描述来模拟一下就可以了。

首先我们先设计我们的比较函数:分数从高到低排,分数相同时按编号从小到大排。

然后呢,循环R轮。

在最开始需要使用比较函数对这 2n 个人进行一下排序。

然后接下来(R轮里面的)每一轮,我都比较相邻的两个元素,然后实力高一点的那个加一分;然后再按照比较函数拍一下序。

实现代码如下(开了O2优化):

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. const int maxn = 200200;
  4. int n, R, Q;
  5. struct Node {
  6. int id, s, w;
  7. } a[maxn];
  8. bool cmp(Node a, Node b) { return a.s > b.s || a.s == b.s && a.id < b.id; }
  9. int main() {
  10. scanf("%d%d%d", &n, &R, &Q);
  11. n *= 2;
  12. for (int i = 0; i < n; i ++) a[i].id = i+1;
  13. for (int i = 0; i < n; i ++) scanf("%d", &a[i].s);
  14. for (int i = 0; i < n; i ++) scanf("%d", &a[i].w);
  15. sort(a, a+n, cmp);
  16. while (R --) {
  17. for (int i = 0; i < n; i += 2) {
  18. if (a[i].w > a[i+1].w) a[i].s ++;
  19. else a[i+1].s ++;
  20. }
  21. sort(a, a+n, cmp);
  22. }
  23. printf("%d\n", a[Q-1].id);
  24. return 0;
  25. }

表达式的值

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

本题涉及算法:前缀表达式转后缀表达式,计算结果的时候有用到递归思想。

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

作者:zifeiy

2011年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. 2013年NOIP普及组复赛题解

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

  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. 灵动微本土MCU厂商具有吸引力的增长点

    作为各种电子产品的控制和处理核心,微控制单元(MCU)器件是一种集成微处理器(CPU).存储器(RAM/ROM).计数器,以及I/O端口的芯片.从MCU内核架构来看,单片机有历经多年的8051,基于A ...

  2. Python之路--协程/IO多路复用

    引子: 之前学习过了,线程,进程的概念,知道了在操作系统中进程是资源分配的最小单位,线程是CPU调度的最小单位.按道理来说我们已经算是把CPU的利用率提高很多了.但是我们知道无论是创建多进程还是创建多 ...

  3. vue-waterfall2 基于Vue.js 瀑布流组件

    vue-waterfall2 1.宽度自适应,数据绑定特效(适用于上拉加载更多) 2.自定义程度高 3.使用极为简便,适用于PC/移动端 4.提供resize(强制刷新布局-适用于下拉刷新)/mix( ...

  4. iOS 中的 Deferred Deep Linking(延迟深度链接)

    http://www.cocoachina.com/ios/20160105/14871.html Deep Linking 其实 deep linking 并不是一个新名词,在 web 开发领域,区 ...

  5. replace all

    OPTION COPY OUTREC FINDREP=(INOUT=(X'0E',X'400E', X'0F',X'0F40'))

  6. 【JZOJ4895】【NOIP2016提高A组集训第16场11.15】三部曲

    =v= 因为外来的入侵,国王决定在某些城市加派士兵.所有城市初始士兵数量为0.当城市 被加派了k名士兵时.城市i的所有子城市需要被加派k+1名士兵.这些子城市的所有子城市需要被加派k+2名士兵.以此类 ...

  7. JS BOM 窗口中的使用

    1,弹框的种类 2,打开一个新页面 子窗口操作父窗口,打开新窗口显示内容open("opener.html","haha","width=300,he ...

  8. jquery 回车提交事件

    $("body").keydown(function(){ if(event.keyCode == "13"){ //13是回车键的位置 } })

  9. 洛谷 P2568 GCD(莫比乌斯反演)

    题意:$\sum_{i=1}^{n}\sum_{j=1}^{n}[gcd(i,j)\epsilon prime]$. 对于这类题一般就是枚举gcd,可得: =$\sum_{d\epsilon prim ...

  10. 非阻塞模式下,虽然connect出错,但是getsockopt取得的错误却是0的问题

    调试项目代码时,发现了一个奇怪问题,记录如下: 非阻塞模式下,connect发起建链,返回-1(这在非阻塞模式下是很正常的现象).然后将该socket的写事件进行监听,在写事件触发后,getsocko ...