题目涉及算法:

  • 明明的随机数:简单模拟;
  • 开心的金明:01背包;
  • Jam的计数法:模拟;
  • 数列:二进制。

明明的随机数

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

简单模拟:排序+去重。使用 sort + unique 实现。

实现代码如下:

#include <bits/stdc++.h>
using namespace std;
int n, a[111];
int main() {
cin >> n;
for (int i = 0; i < n; i ++) cin >> a[i];
sort(a, a+n);
n = unique(a, a+n) - a;
cout << n << endl;
for (int i = 0; i < n; i ++) {
if (i) putchar(' ');
cout << a[i];
}
cout << endl;
return 0;
}

开心的金明

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

这道题目就是一道裸的01背包,每件物品的体积对应价格,价值对应价格和重要度的乘积。

实现代码如下:

#include <bits/stdc++.h>
using namespace std;
const int maxn = 30030;
int V, n, c, p, f[maxn];
int main() {
cin >> V >> n;
while (n --) {
cin >> c >> p;
for (int i = V; i >= c; i --)
f[i] = max(f[i], f[i-c] + c * p);
}
cout << f[V] << endl;
return 0;
}

Jam的计数法

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

模拟题,找到单调递增的字符串的下一个排列。

实现代码如下:

#include <bits/stdc++.h>
using namespace std;
bool used[26];
char ch[30];
int s, t, w; bool get_next() {
memset(used, 0, sizeof(used));
for (int i = 0; i < w; i ++) used[ ch[i] - 'a' ] = true;
for (int i = w-1; i >= 0; i --) {
int st = ch[i] - 'a';
int cnt = 0;
for (int j = st+1; j <= t; j ++) if (!used[j]) cnt ++;
if (cnt >= w-i) {
int id = i;
for (int j = st+1; j <= t; j ++) {
if (!used[j]) {
ch[id++] = 'a' + j;
if (id >= w) break;
}
}
return true;
}
used[st] = false;
}
return false;
} int main() {
cin >> s >> t >> w >> ch;
s --; t --;
for (int i = 0; i < 5 && get_next(); i ++)
cout << ch << endl;
return 0;
}

数列

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

这道题目需要对二进制有一个理解。

对于 N ,如果我们将其转成二进制数是 \(a_ma_{m-1} \dots a_1a_0\) ,其中 \(a_i\) 为1表示结果中包含 \(k^i\) ,\(a_i\) 为0表示结果中不包含 \(k^i\) 。

那么我们可以发现:

N 对应的数 \(\gt\) N-1 对应的数 \(\gt\) N-2对应的数 …… \(\gt\) 1 对应的数 \(\gt\) 0 对应的数。

所以我们的答案就是N对应的二进制中所有为1的那些位i的 \(\sum k^i\) 。

实现代码如下:

#include <bits/stdc++.h>
using namespace std;
int n, k;
long long ans;
long long quick_mi(long long a, int b) {
if (b == 0) return 1;
if (b == 1) return a;
long long t = quick_mi(a, b/2);
t *= t;
if (b % 2) t *= a;
return t;
}
int main() {
cin >> k >> n;
for (int i = 0; i <= 10; i ++)
if ( n & (1<<i) )
ans += quick_mi(k, i);
cout << ans << endl;
return 0;
}

作者:zifeiy

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

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

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

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

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

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

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

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

随机推荐

  1. CSS3渐变效果

    一.线性渐变linear-gradient  1.使用方法: background:-webkit-linear-gradient(red,blue);background:-moz-linear-g ...

  2. 当inline-block和text-indent遇到IE6,IE7

    在实际应用中,考虑到seo,很多button,icon都要用到inline-block和text-indent来处理,例如: <a href="#" class=" ...

  3. 【水滴石穿】react-native-ble-demo

    项目的话,是想打开蓝牙,然后连接设备 点击已经连接的设备,我们会看到一些设备 不过我这边在开启蓝牙的时候报错了 先放作者的项目地址: https://github.com/hezhii/react-n ...

  4. Liferay JSP Tag Libraries介绍

    Liferay自带了很多标签库,这极大地提高了开发Liferay项目的效率. 下面让我们一起来探索吧. 什么是标签库? 什么是JSP标签? 什么是JSTL? 标签库由下面这几部分组成: Tag Lib ...

  5. 【机器学习PAI实战】—— 玩转人工智能之商品价格预测

    摘要: 我们经常思考机器学习,深度学习,以至于人工智能给我们带来什么?在数据相对充足,足够真实的情况下,好的学习模型可以发现事件本身的内在规则,内在联系.我们去除冗余的信息,可以通过最少的特征构建最简 ...

  6. 关于 SSD 的接口和相关名词(2019-09-10)

    关于 SSD 的接口和相关名词 了解了很多天的 SSD,太多的名词. 先记录一下. SATA MSATA M2 NVME NGFF U2 TODO: 后续收集相关信息.

  7. oralce MTS

    MTS的组件包括: processes on the system. communication software. the shared global section (SGA).          ...

  8. android GUI 流程记录

    ViewRootImpl 与 wms ViewRootImple里的 WindowSeesion是WindowManagerService的proxy, 通过这个句柄来调用WMS的功能而W是 wms用 ...

  9. DRP 2016-06-30 16:36 314人阅读 评论(21) 收藏

    学习drp有一段时间了,其实从很久以前,再提高班的学习就已经不是单纯的学习,学习总是伴随着项目.这就使得我们的学习不可能全天的,大把大把时间的学习只出现在第一和第二年,所以,各自珍惜吧. DRP(Di ...

  10. SDUT-2124_基于邻接矩阵的广度优先搜索遍历

    数据结构实验之图论一:基于邻接矩阵的广度优先搜索遍历 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 给定一个无向连通图 ...