11.5NOIP模拟赛解题报告
心路历程
预计得分:\(100 + 40 + 30 = 170\)
实际得分:\(100 +100 + 50 = 250\)
辣鸡数据毁我青春
T1一眼不会做感觉要凉
T2好像一波折半搜索就做完了
T3好像是神仙题不会做。。
打完T1暴力后去淦T2,结果最后在排序的时候把greater<LL>()
写成了greater<int>()
,不过感谢辣鸡数据放我一条活路。。
手玩了一下T1发现根本不需要决策,只算算期望就行了,然后大胆猜了个结论就不管了
这时候大概还剩\(1.5h\),感觉T3一定是个不可做题于是手动把难度加了两个档次。。
明明能\(O(1)\)算出来的我非要推个\(O(10^8)\)的组合数。于是就凉了。。
Sol
T1
直接算期望是对的。
证明的话可以设每个决策的概率然后算一下贡献。发现其中一种决策一定不会比另一种优
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
using namespace std;
const int MAXN = 1001, INF = 1e9 + 10;
inline int read() {
char c = getchar(); int x = 0, f = 1;
while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();}
while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return x * f;
}
int N;
double P[MAXN][MAXN], ans, f[MAXN][MAXN];
int main() {
freopen("game.in", "r", stdin);
freopen("game.out", "w", stdout);
N = read();
for(int i = 1; i <= N; i++) for(int j = 0; j <= i - 1; j++) scanf("%lf", &P[i][j]);
memset(f, 0, sizeof(f));
f[0][0] = 1;
for(int i = 1; i <= N; i++)
for(int j = 0; j < i; j++)
f[i][j + 1] += f[i - 1][j] * P[i][j],
f[i][j] += f[i - 1][j] * (1 - P[i][j]);
for(int i = 1; i <= N; i++) ans += i * f[N][i];
printf("%.2lf", ans);
return 0;
}
T2
折半搜索板子题。。
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
#include<vector>
#define LL long long
using namespace std;
const int MAXN = 3e6 + 10, INF = 1e9 + 10, mod = 0;
inline int read() {
char c = getchar(); int x = 0, f = 1;
while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();}
while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return x * f;
}
LL N, M, st[2][MAXN], t[2], a[MAXN];
vector<LL> res;
void dfs(int x, int Lim, LL val, int opt) {
if(x == Lim) {st[opt][++t[opt]] = val; return ;}
dfs(x + 1, Lim, val + res[x], opt);
dfs(x + 1, Lim, val, opt);
}
void solve(int l, int r, int opt) {
res.clear();
for(int i = l; i <= r; i++) res.push_back(a[i]);
dfs(0, res.size(), 0, opt);
}
int main() {
freopen("cake.in", "r", stdin);
freopen("cake.out", "w", stdout);
N = read(); M = read();
for(int i = 1; i <= N; i++) a[i] = read();
int mid = N / 2;
solve(1, mid, 0); solve(mid + 1, N, 1);
sort(st[0] + 1, st[0] + t[0] + 1, greater<int>());
sort(st[1] + 1, st[1] + t[1] + 1);
int j = 1; LL ans = 0;
for(int i = 1; i <= t[0]; i++) {
while((j + 1 <= t[1]) && (st[0][i] + st[1][j + 1] <= M)) j++;
if(st[0][i] + st[1][j] <= M) ans = max(ans, st[0][i] + st[1][j]);
}
cout << M - ans;
return 0;
}
T3
比着学弟的代码抄了一下午发现他写的是假的qwq
心态爆炸。。
11.5NOIP模拟赛解题报告的更多相关文章
- 11.1NOIP模拟赛解题报告
心路历程 预计得分:\(100 + 100 + 50\) 实际得分:\(100 + 100 + 50\) 感觉老师找的题有点水呀. 上来看T1,woc?裸的等比数列求和?然而我不会公式呀..感觉要凉 ...
- 11.7NOIP模拟赛解题报告
心路历程 预计得分:\(50 + 100 + 100\) 实际得分:\(50 + 100 +100\) T2 T3两道数据结构题美滋滋,然而写完就过去\(3h\)美滋滋 T1数学题学弟们都会做Orzz ...
- 11.6NOIP模拟赛解题报告
心路历程 预计得分:\(100 + 100 + 100 = 300\) 实际得分:\(100 +100 +100 = 300\) 学OI两年终于AK了一次qwq(虽然题目炒鸡水..) 纪念一下这令人激 ...
- 10.30 NFLS-NOIP模拟赛 解题报告
总结:今天去了NOIP模拟赛,其实是几道USACO的经典的题目,第一题和最后一题都有思路,第二题是我一开始写了个spfa,写了一半中途发现应该是矩阵乘法,然后没做完,然后就没有然后了!第二题的暴力都没 ...
- 20201101gryz模拟赛解题报告
写在前面 2020rp++ 停课的第一场模拟赛 拿上一年的上一年的day1来考的, 结果得分期望220pts,实际135pts,rank3,太菜了 考着考着机房灯突然灭了,当时慌的一批 以为断电代码要 ...
- 2018.10.26NOIP模拟赛解题报告
心路历程 预计得分:\(100 + 100 + 70\) 实际得分:\(40 + 100 + 70\) 妈妈我又挂分了qwq..T1过了大样例就没管,直到临考试结束前\(10min\)才发现大样例是假 ...
- 2018.10.17NOIP模拟赛解题报告
心路历程 预计得分:\(100 + 100 +100\) 实际得分:\(100 + 100 + 60\) 辣鸡模拟赛.. 5min切掉T1,看了一下T2 T3,感觉T3会被艹爆因为太原了.. 淦了20 ...
- 2018.10.16 NOIP模拟赛解题报告
心路历程 预计得分:\(100 + 100 + 20 = 220\) 实际得分:\(100 + 100 + 30 = 230\) 辣鸡模拟赛.. T1T2都是一眼题,T3考验卡常数还只有一档暴力分. ...
- 20201115gryz模拟赛解题报告
写在前面 T1:期望100pts,实际0pts(7:50 ~ 8:50 T2:期望0pts,实际0pts(10:00 ~ 10:35 T3:期望20pts,实际40pts( 9:10 ~ 10:00, ...
随机推荐
- 逆向学习-DLL注入
DLL注入技术,可以实现钩取API,改进程序,修复Bug. DLL注入指的是向运行中的其他进程强制插入特定的DLL文件. DLL注入命令进程自行调用LoadLibrary()API,加载用户指定的DL ...
- 洛谷P5156 [USACO18DEC]Sort It Out
这题就是让你求字典序第k小的最短乱序子序列 转换一下,其实就是字典序第k大的最长上升子序列 就统计一下以i结尾的最长上升子序列\(f[i]\),长度为i的上升子序列的开头组成的集合\(v[i]\),转 ...
- JavaWeb学习笔记(十七)—— 数据库连接池
一.数据库连接池概述 1.1 为什么使用数据库连接池 如果用户每次请求都向数据库获得连接,而数据库创建连接通常需要消耗相对较大的资源,创建时间也较长.假设网站一天10万访问量,数据库服务器就需要创建1 ...
- 编写高质量代码:Web前端开发修炼之道(四)
这一节是继上一节高质量的Javascript 7)编程实用技巧 1:弹性 从 一个标签区和内容区的实例(就是点击不同的标签菜单显示不同的内容块)来说明不需要每个tabmenu都设置onclick事件, ...
- 博客主题皮肤探索-GitHub和jsdelivr的使用
有个前言 本萌并不会前端相关的知识,一切都是自己慢慢摸索出来的,如果存在代码方面的不足,请尽快告诉我~~~ 使用一个主题 目前我博客使用是 https://www.cnblogs.com/bndong ...
- API Monitor程序分析工具简介
API Monitor是一个免费软件,可以让你监视和控制应用程序和服务,取得该应用程序的API调用情况. 它是一个强大的工具,看到的应用程序和服务是如何工作的,或跟踪,你在自己的应用程序的问题. AP ...
- nginx(三)-动静分离
什么叫动静分离 所谓动静分离就是说我们的图片,css,js之类的文件都交给nginx来处理,nginx处理不了的,比如jsp就交给tomcat来处理. 有人计算过,nginx代理处理静态请求远远优于t ...
- 一篇Java图片验证码生成的代码
package projectUtil; /** * @author tian * @date 2019/4/1015:58 */ import javax.imageio.ImageIO; impo ...
- 推荐-Everything搜索工具
简介: windows操作系统下极其强大的文件搜索工具. 下载: https://www.voidtools.com/downloads/ 推荐理由: 速度之快难以想象,日常工作必备工具之一. 发现的 ...
- python3.6 for pygame安装
首先下载好文件: pygame下载网址:http://www.lfd.uci.edu/~gohlke/pythonlibs/#pygame 找到pygame-1.9.2b8-cp36-cp36m-wi ...