题目涉及算法:

  • 珠心算测验:枚举;
  • 比例简化:枚举;
  • 螺旋矩阵:模拟;
  • 子矩阵:状态压缩/枚举/动态规划

珠心算测验

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

因为数据量比较小,直接暴力枚举即可。

实现代码如下:

#include <bits/stdc++.h>
using namespace std;
const int maxn = 110;
int n, a[maxn], cnt;
bool exists[20020];
int main() {
cin >> n;
for (int i = 0; i < n; i ++) cin >> a[i];
for (int i = 0; i < n; i ++) for (int j = i+1; j < n; j ++) exists[ a[i] + a[j] ] = true;
for (int i = 0; i < n; i ++) cnt += exists[ a[i] ];
cout << cnt << endl;
return 0;
}

比例简化

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

只需要从1到L遍历分母 \(b\) ,根据 \(b\) 我们能够马上推导出分子 \(a = \lceil \frac{A \times b}B \rceil\) ,然后假设我们当前的答案的分子是 \(A'\) 分母是 \(B'\) ,则当 \(a \le L\) 条件满足是,我们就需要去比较一下 \(\frac{a}{b} \lt \frac{A'}{B'}\) 是否成立,如果成立的话需要更新一下答案为 \(\frac{a}{b}\) ,但是比较实数会损失精度,所以比较规则应该是 \(a \times B' \lt A' \times b\) 。

实现代码如下:

#include <bits/stdc++.h>
using namespace std;
long long A, B, L, ans_a, ans_b;
int main() {
cin >> A >> B >> L;
for (long long b = 1; b <= L; b ++) {
long long a = (A * b + B - 1) / B;
if (a > L) continue;
if (!ans_b || ans_a * b > a * ans_b) {
ans_a = a;
ans_b = b;
}
}
cout << ans_a << " " << ans_b << endl;
return 0;
}

螺旋矩阵

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

本题涉及算法:模拟。

但是一格一格模拟是不对的,因为 \(n \le 30000\) ,\(n^2\) 会超时。

一行一列模拟是可以的,但是一圈一圈模拟更好。

我们先计算外面走了几个圈(这恰巧是一个等差数列),然后再计算最后走的那一圈(此时最多2行2列),即可获得目的地各自的编号。

实现代码如下:

#include <bits/stdc++.h>
using namespace std;
long long n, x, y; long long get_gezi_number(long long n, long long x, long long y) {
long long cnt = 0;
long long d = min( min(x-1, n-x), min(y-1, n-y) );
cnt = ( 4 * n - 4 + 4 * (n-2*d+2) - 4 ) * d / 2;
long long x1 = d+1, Y1 = d+1, x2 = n-d, y2 = n-d;
if (x1 == x) cnt += y-Y1+1;
else if (y2 == y) cnt += (n-2*d-1) + x-x1+1;
else if (x2 == x) cnt += 2 * (n-2*d-1) + y2-y+1;
else cnt += 3 * (n-2*d-1) + x2-x+1;
return cnt;
} int main() {
cin >> n >> x >> y;
cout << get_gezi_number(n, x, y) << endl;
return 0;
}

子矩阵

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

本题涉及知识点:状态压缩/枚举/DP。

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

作者:zifeiy

2014年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. 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. 全球城市群Megalopolis

    Megalopolis From Wikipedia, the free encyclopedia   (Redirected from Megalopolis (city type))   &quo ...

  2. 【linux配置】Linux系统下安装rz/sz命令以及使用说明

    Linux系统下安装rz/sz命令以及使用说明 对于经常使用Linux系统的人员来说,少不了将本地的文件上传到服务器或者从服务器上下载文件到本地,rz / sz命令很方便的帮我们实现了这个功能,但是很 ...

  3. vue-cli3 搭建的前端项目基础模板

    基于 vue-cli3 搭建的前端模板,fork 或 clone 本仓库,即可搭建完成一个新项目的基础模板,源码地址,欢迎 star 或 fork 特性 CSS 预编译语言:less Ajax: ax ...

  4. C++之正则表示,字符串是否为全字母或者全数字

    bool isLetter(std::string& inputtext){ tr1::regex reg("^[A-Za-z]+$"); bool bValid = tr ...

  5. 计算机网络3.2&3.3(第二节介质&第三节多路复用)

    有限的传播介质 双绞线 双绞线电缆 双绞线总结 2 同轴电缆 粗细电缆的传输距离 现在基本都用双绞线和光线 同轴电缆用于居民小区和家庭使用 3 光纤 光纤中以光信号的形式进行传播 正如我们现在看到这样 ...

  6. NOIP模拟 17.8.20

    NOIP模拟17.8.20 A.阶乘[题目描述]亲爱的xyx同学正在研究数学与阶乘的关系,但是他喜欢颓废,于是他就制作了一个和阶乘有关系的数学游戏:给出两个整数 n,m,令 t = !n,每轮游戏的流 ...

  7. 如何在liferay 7 mvc-portlet中调用service-builder项目生成的service

    不想写了,贴大神帖子 https://web.liferay.com/web/zhao.jin/blog/-/blogs/creating-service-builder-mvc-portlet-in ...

  8. MySQL——外键

    概念 关键字:foreign key,也叫做外键约束! 如果一个实体A的某个字段,刚好指向另一个实体B的主键,那么实体A的这个字段就叫做外键: 所以,简单来说,外键就是本表的某个字段指向外表的主键! ...

  9. Sublime Text3 安装less

    1.安装Sublime 插件 (1)安装LESS插件:因为Sublime不支持Less语法高亮,所以,先安装这个插件,方法: ctrl+shift+p>install Package>输入 ...

  10. PHP学习(类型转化)

    PHP 在变量定义中不需要(或不支持)明确的类型定义:变量类型是根据使用该变量的上下文所决定的.也就是说,如果把一个 string 值赋给变量 $var , $var 就成了一个 string .如果 ...