2015年NOIP普及组复赛题解
题目涉及算法:
- 金币:入门题;
- 扫雷游戏:入门题;
- 求和:简单数学推导;
- 推销员:贪心。
金币
题目链接:https://www.luogu.org/problem/P2669
入门题,直接开一个循环遍历一下就可以了。
实现代码如下:
#include <bits/stdc++.h>
using namespace std;
int n, ans = 0;
int main() {
cin >> n;
for (int i = 1; n; i ++) {
int t = min(i, n);
ans += i *t;
n -= t;
}
cout << ans << endl;
return 0;
}
扫雷游戏
题目链接:
基础题,直接遍历一下地图(对于每个格子,统计一下周围8个格子)就可以实现地雷的统计。
实现代码如下:
#include <bits/stdc++.h>
using namespace std;
const int maxn = 110;
int n, m, c[maxn][maxn];
char maze[maxn][maxn];
int dir[8][2] = { -1, -1, -1, 0, -1, 1, 0, -1, 0, 1, 1, -1, 1, 0, 1, 1 };
inline bool in_map(int x, int y) { return x >= 0 && x < n && y >= 0 && y < m; }
int main() {
cin >> n >> m;
for (int i = 0; i < n; i ++) cin >> maze[i];
for (int i = 0; i < n; i ++) for (int j = 0; j < m; j ++) {
if (maze[i][j] == '*') for (int k = 0; k < 8; k ++) {
int x = i + dir[k][0], y = j + dir[k][1];
if (in_map(x, y)) c[x][y] ++;
}
}
for (int i = 0; i < n; i ++) {
for (int j = 0; j < m; j ++) {
if (maze[i][j] == '*') putchar('*');
else cout << c[i][j];
}
cout << endl;
}
return 0;
}
求和
题目链接:https://www.luogu.org/problem/P2671
这道题目是一道简单的数学推导。
首先,因为一共有m种颜色,并且我们只有具有相同奇偶性的一对数才能凑成x和z,所以我们将所有从1到n的编号划分进 \(2 \times m\) 个集合,对于编号 \(i\):
- 如果 \(i\) 是奇数,将其归到 \(2 \times color[i]\) 集合中;
- 如果 \(i\) 是偶数,将其归到 \(2 \times color[i] - 1\) 集合中。
然后我们去遍历每一个集合。
如果该集合的元素个数是 \(sz\) ,并且我们设该集合中所有元素数值和 \(S = \sum number[i]\) ,则我们遍历集合中的每个元素 \(x\) ,并将
\((sz-1) \times x \times number[x] + x \times (S - number[x])\)
的结果加进我们的答案中。
实现代码如下:
#include <bits/stdc++.h>
using namespace std;
const int maxn = 200020;
const long long MOD = 10007;
vector<int> vec[maxn];
int n, m, color[maxn];
long long ans, num[maxn], sum[maxn];
int main() {
cin >> n >> m;
for (int i = 1; i <= n; i ++) {
cin >> num[i];
num[i] %= MOD;
}
for (int i = 1; i <= n; i ++) cin >> color[i];
for (int i = 1; i <= n; i ++) {
int id = (i % 2) ? (color[i] * 2) : (color[i] * 2 - 1);
vec[id].push_back(i);
sum[id] = (sum[id] + num[i]) % MOD;
}
for (int i = 1; i <= 2*m; i ++) {
int sz = vec[i].size();
if (sz <= 1) continue;
for (int j = 0; j < sz; j ++) {
int v = vec[i][j];
long long tmp = (long long)(sz-1) * (long long)v * (long long) num[v] % MOD;
tmp += (long long) v * (sum[i] - num[v] + MOD) % MOD;
ans = (ans + tmp) % MOD;
}
}
cout << ans << endl;
return 0;
}
推销员
题目链接:https://www.luogu.org/problem/P2672
这道题目是贪心,贪心的思想是:
选择 \(m\) 户人家的最大疲劳值应该是以下两种方案中的较大值:
- 方案一:选择 \(a[i]\) 最大的 \(m\) 户人家;
- 方案二:选择 \(a[i]\) 最大的 \(m-1\) 户人家,以及剩下的 \(n-(m-1)\) 户人家中 \(2 \times s[i] + a[i]\) 最大的那户人家
所以,我们可以给 \(n\) 户人家按照 \(a[i]\) 从大到小金星排序。
然后在开三个数组(这3个数组用到了DP来进行求解):
suma[i]
:表示 \(\sum_{j=1}^{i}a[j] + 2 \times \max_{j=1}^{i}(s[j])\) ,推导公式:suma[i] = suma[i-1] + a[i]
maxs[i]
:表示 \(\max_{j=1}^{i} s[j]\) ,推导公式:maxs[i] = maxs[i-1] + s[i]
maxsa[i]
:表示 \(\max_{j=i}^{n} (2 \times s[j] + a[j])\) ,推导公式:maxsa[i] = max(maxsa[i+1], 2 \times s[i] + a[i])
然后我们要在 \(n\) 户人家里面选择 \(m\) 户人家访问的最大疲劳值就是 sum[m] + 2 * maxs[m]
和 suma[m-1] + 2 * maxs[i]
的较大值。
实现代码如下:
#include <bits/stdc++.h>
using namespace std;
const int maxn = 100100;
int n, s[maxn], a[maxn], idx[maxn], suma[maxn], maxs[maxn], maxsa[maxn];
bool cmp(int i, int j) {
return a[i] > a[j];
}
int main() {
cin >> n;
for (int i = 1; i <= n; i ++) cin >> s[i];
for (int i = 1; i <= n; i ++) cin >> a[i];
for (int i = 1; i <= n; i ++) idx[i] = i;
sort(idx+1, idx+1+n, cmp);
for (int i = 1; i <= n; i ++)
suma[i] = suma[i-1] + a[idx[i]], maxs[i] = max(maxs[i-1], s[idx[i]]);
for (int i = n; i >= 1; i --)
maxsa[i] = max(maxsa[i+1], s[idx[i]] * 2 + a[idx[i]]);
for (int i = 1; i <= n; i ++)
cout << max(suma[i]+2*maxs[i], suma[i-1]+maxsa[i]) << endl;
return 0;
}
作者:zifeiy
2015年NOIP普及组复赛题解的更多相关文章
- 2010年NOIP普及组复赛题解
题目及涉及的算法: 数字统计:入门题: 接水问题:基础模拟题: 导弹拦截:动态规划.贪心: 三国游戏:贪心.博弈论. 数字统计 题目链接:洛谷 P1179 这道题目是一道基础题. 我们只需要开一个变量 ...
- 2017年NOIP普及组复赛题解
题目涉及算法: 成绩:入门题: 图书管理员:模拟: 棋盘:最短路/广搜: 跳房子:RMQ/二分答案/DP(本人解法). 成绩 题目链接:https://www.luogu.org/problemnew ...
- 2016年NOIP普及组复赛题解
题目涉及算法: 买铅笔:入门题: 回文日期:枚举: 海港:双指针: 魔法阵:数学推理. 买铅笔 题目链接:https://www.luogu.org/problem/P1909 设至少要买 \(num ...
- 2014年NOIP普及组复赛题解
题目涉及算法: 珠心算测验:枚举: 比例简化:枚举: 螺旋矩阵:模拟: 子矩阵:状态压缩/枚举/动态规划 珠心算测验 题目链接:https://www.luogu.org/problem/P2141 ...
- 2013年NOIP普及组复赛题解
题目涉及算法: 计数问题:枚举: 表达式求值:栈: 小朋友的数字:动态规划: 车站分级:最长路. 计数问题 题目链接:https://www.luogu.org/problem/P1980 因为数据量 ...
- 2011年NOIP普及组复赛题解
题目涉及算法: 数字反转:模拟: 统计单词数:模拟: 瑞士轮:模拟/排序: 表达式的值:后缀表达式/DP. 数字反转 题目链接:https://www.luogu.org/problem/P1307 ...
- 2008年NOIP普及组复赛题解
题目涉及算法: ISBN号码:简单字符串模拟: 排座椅:贪心: 传球游戏:动态规划: 立体图:模拟. ISBN号码 题目链接:https://www.luogu.org/problem/P1055 简 ...
- 2005年NOIP普及组复赛题解
题目涉及算法: 陶陶摘苹果:入门题: 校门外的树:简单模拟: 采药:01背包: 循环:模拟.高精度. 陶陶摘苹果 题目链接:https://www.luogu.org/problem/P1046 循环 ...
- 2018年NOIP普及组复赛题解
题目涉及算法: 标题统计:字符串入门题: 龙虎斗:数学题: 摆渡车:动态规划: 对称二叉树:搜索. 标题统计 题目链接:https://www.luogu.org/problem/P5015 这道题目 ...
随机推荐
- LUOGU P3112 [USACO14DEC]后卫马克Guard Mark
题目描述 Farmer John and his herd are playing frisbee. Bessie throws the frisbee down the field, but it' ...
- HDU 1724 自适应辛普森法
//很裸的积分题,直接上模板 #include<stdio.h> #include<math.h> int aa, bb; //函数 double F(double x){ - ...
- 杨柳絮-Info:春天将不再漫天飞“雪”,济源治理杨柳絮在行动
ylbtech-杨柳絮-Info:春天将不再漫天飞“雪”,济源治理杨柳絮在行动 1.返回顶部 1. 天气暖和了,连心情都是阳光的.然而,在这美好的时刻,漫天飞舞的杨柳絮,甚是煞风景.<ignor ...
- ASP.NET 自定义服务器控件
文章内容 本文通过创建一个最简单的服务器控件,演示开发服务器端控件的流程. 文章内容整理自MSDN的编程指南,原文地址在文章末尾的资源中. 本文创建一个简单的服务器控件,名为 RedLabel. ...
- nginx简介 (转)
1.Nginx概述 2.Nginx安装与控制指令 3.Nginx如何工作 4.Nginx配置实例 4.1如何配置Linux下Nginx 4.1.1配置Nginx代理HTTP请求到Tomcat 4.1. ...
- iOS 微信支付如果遇到跳转只有一个确定请看这里
http://www.cocoachina.com/bbs/read.php?tid-321546.html 今天在联调微信支付,不得不说,和它比起来,阿里的支付sdk真的是太好用了.果然和后端同学在 ...
- docker 常用的命令
1.运行容器 sudo docker run -d -t -p : --name demo ubuntu:16.04 2.删除容器 sudo docker rm -f demo 3.在容器中安装必备软 ...
- react-cnode
感谢无私开源的程序员们~~~代码因为你们更加美腻~ //根index.js import React, { Fragment } from 'react'; import ReactDOM from ...
- bzoj4033 树上染色
Description 有一棵点数为N的树,树边有边权.给你一个在0~N之内的正整数K,你要在这棵树中选择K个点,将其染成黑色,并 将其他的N-K个点染成白色.将所有点染色后,你会获得黑点两两之间的距 ...
- shell学习(19)- find查找命令
Linux find命令用来在指定目录下查找文件.任何位于参数之前的字符串都将被视为欲查找的目录名.如果使用该命令时,不设置任何参数,则find命令将在当前目录下查找子目录与文件.并且将查找到的子目录 ...