2017-3-01 test
三道好像都是HDU上的题QAQ
题目名称都没改,差评
T1:http://acm.hdu.edu.cn/showproblem.php?pid=5073
被卡精度了QAQ
先排一发序,然后发现最后未动过的点一定是一段连续的区间,且其他点都被移动至其平均数处
所以直接O(n)乱搞即可
P.S.HDU上好像不能用long double
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
using namespace std;
const int Mx=;
int n,k;
long double ans,tmp,sum,ave,a[Mx];
bool cmp(long double a,long double b) { return a<b; }
int main()
{
int T; scanf("%d",&T);
for(int t=;t<=T;t++)
{
printf("Case #%d:\n",t);
tmp=,sum=;
scanf("%d%d",&n,&k);
for(int i=;i<=n;i++) scanf("%LF",&a[i]);
if(n==k) { cout<<"0.000000"<<endl; continue; }
sort(a+,a++n,cmp);
for(int i=;i<=n-k;i++) tmp+=a[i]*a[i],sum+=a[i];ave=sum/(n-k);
ans=tmp-*ave*sum+(n-k)*ave*ave;
for(int l=,r=n-k+;r<=n;l++,r++)
{
tmp+=a[r]*a[r]-a[l]*a[l];
sum+=a[r]-a[l];
ave=sum/(n-k);
ans=min(ans,tmp-*ave*sum+(n-k)*ave*ave);
}
printf("%.8LF\n",ans);
}
return ;
}
T2:http://acm.hdu.edu.cn/showproblem.php?pid=5833
一言不合就数论QAQ
首先先预处理2000以内的素数,然后将a[]质因数分解
我们发现,一个完全平方数的各个质因子都是偶数次方,所以每次乘起来就等价于把系数^1
所以可以构造转移矩阵,第i行j列表示第j个素数在a[i]中的系数%2
高斯一发然后答案即为pow(2,自由元的个数)-1,记得开long long
P.S.自由元:消完之后一行都是0
#include <cstdio>
#include <cmath>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int Mx=;
const long long p=1e9+;
int n,cnt,pr[Mx],vis[Mx],tran[][];
void pre()
{
for(int i=;i<=;i++)
{
int jud=;
for(int j=;j*j<=i;j++)
if(i%j==) jud=;
if(jud) pr[++cnt]=i;
}
}
long long power(long long a,long long b)
{
long long c=;
while(b)
{
if(b&) c=c*a%p;
a=a*a%p;
b>>=;
}
return c;
}
int gauss()
{
int i=;
for(int j=;i<=cnt&&j<=n;i++,j++)
{
int tmp=i;
for(int k=i+;k<=cnt;k++)
if(tran[k][j]>tran[tmp][j]) tmp=k;
if(tmp!=i)
for(int k=j;k<=n+;k++) swap(tran[tmp][k],tran[i][k]);
if(tran[i][j]==) { i--; continue; }
for(int k=i+;k<=cnt;k++)
{
if(!tran[k][j]) continue;
for(int l=j;l<=n+;l++)
tran[k][l]=tran[k][l]^tran[i][l];
}
}
return n-(i-);
}
int main()
{
pre();
int T; scanf("%d",&T);
for(int t=;t<=T;t++)
{
memset(tran,,sizeof(tran));
printf("Case #%d:\n",t);
scanf("%d",&n);
for(int i=;i<=n;i++)
{
long long x; scanf("%lld",&x);
for(int j=;j<=cnt;j++)
{
int tot=;
while(x%pr[j]==)
x/=pr[j],tot++;
tran[j][i]=tot&;
}
}
printf("%lld\n",(long long) power(,gauss())-);
}
return ;
}
T3:http://acm.hdu.edu.cn/showproblem.php?pid=5770
好麻烦啊QAQ调了半天调不出来只能把std放上去了QAQ
orz ZSQ:http://blog.csdn.net/v5zsq/article/details/52170616
对于一组钥匙和宝箱u,v及其lca,我们可以分类讨论,有以下四种情况
1、u!=lca&&v!=lca:要想拿到宝箱,起点必须在u的子树中,终点必须在v的子树中
2、u==lca:起点不能在u的子树中,终点必须在v的子树中
3、v==lca:起点不能在v的子树中,终点必须在v的子树中
4、u==v:起点和终点在lca的不同子树中 或 起点or终点在lca的子树中,另一个点不在lca的子树中
这种情况为保证复杂度所以要反过来求不包含该节点的路径
①起点和终点都在lca的同一个儿子中
②起点和终点都不在在lca的子树中,即起点和终点x的dfs序都满足(x<l || x>r)
考虑维护DFS序,将以i为根的子树处理成一个区间[l,r],则每个宝箱可以映射为一个带权矩阵,对应上述情况
建立一个二维平面,平面上的点(x,y)表示从x走到y的价值,点权即为包含该点的所有矩阵的和
最后用扫描线+线段树即可解决
默默吐槽一下,std代码好吃藕啊QAQ(逃~
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
using namespace std; const int N = ;
int to[N << ], nxt[N << ], head[N], cnt;
void add(int x, int y){
to[++ cnt] = y; nxt[cnt] = head[x]; head[x] = cnt;
to[++ cnt] = x; nxt[cnt] = head[y]; head[y] = cnt;
} struct Rec{
int x1, x2, y1, y2, val;
}rec[N * ];
struct Event{
int l, r, y, val, rank;
}events[N * ];
bool operator < (const Event &a, const Event &b){
return a.y < b.y || (a.y == b.y && a.rank < b.rank);
} struct treasure{
int key, chest, val;
}a[N];
int st[N], ed[N], n, m, dfs_clock, dep[N], fa[N][]; int LCA(int x, int y){
if (dep[x] < dep[y]) swap(x, y);
int t = dep[x] - dep[y];
for(int i = ; i < ; i ++) if (t >> i & ) x = fa[x][i];
for(int i = ; i >= ; i --)
if (fa[x][i] != fa[y][i]) x = fa[x][i], y = fa[y][i];
if (x == y) return x;
return fa[x][];
} void dfs(int x){
st[x] = ++ dfs_clock;
for(int i = ; ( << i) <= dep[x]; i ++)
fa[x][i] = fa[fa[x][i - ]][i - ];
for(int i = head[x]; i; i = nxt[i])
if (st[to[i]] == ){
dep[to[i]] = dep[x] + ;
fa[to[i]][] = x;
dfs(to[i]);
}
ed[x] = dfs_clock;
} struct node{
int tag, max;
}t[N << ];
#define mid ((l + r) >> 1)
#define L (o << 1)
#define R (o << 1 | 1)
#define lch L, l, mid
#define rch R, mid + 1, r void Push_up(int o){
t[o].max = max(t[L].max, t[R].max);
}
void change(int o, int v){
t[o].tag += v; t[o].max += v;
}
void Push_down(int o){
if (t[o].tag){
change(L, t[o].tag);
change(R, t[o].tag);
t[o].tag = ;
}
}
void update(int o, int l, int r, int ql, int qr, int v){
if (ql > qr) return;
if (ql <= l && qr >= r) change(o, v);
else{
Push_down(o);
if (ql <= mid) update(lch, ql, qr, v);
if (qr > mid) update(rch, ql, qr, v);
Push_up(o);
}
} int main(){
int T, cs = ;
scanf("%d", &T);
while(cs < T){
printf("Case #%d: ", ++ cs); memset(head, , sizeof head);
memset(st, , sizeof st);
memset(fa, , sizeof fa);
memset(dep, , sizeof dep);
memset(t, , sizeof t);
cnt = dfs_clock = ;
scanf("%d%d", &n, &m);
int x, y;
for(int i = ; i < n; i ++){
scanf("%d%d", &x, &y);
add(x, y);
}
dfs();
// for(int i = 1; i <= n; i ++) printf("st[%d] = %d ed[%d] = %d\n", i, st[i], i, ed[i]);
int tot = , num = , ans = , tmp = ;
for(int i = ; i <= m; i ++){
scanf("%d%d%d", &a[i].key, &a[i].chest, &a[i].val);
int lca = LCA(a[i].key, a[i].chest);
if (a[i].key == a[i].chest){
tmp += a[i].val;
for(int j = head[a[i].key]; j; j = nxt[j])
if (to[j] != fa[a[i].key][]){
rec[++ tot] = (Rec){st[to[j]], ed[to[j]], st[to[j]], ed[to[j]], -a[i].val};
}
if ( <= st[a[i].key] - && ed[a[i].key] + <= n){
rec[++ tot] = (Rec){, st[a[i].key] - , ed[a[i].key] + , n, -a[i].val};
rec[++ tot] = (Rec){ed[a[i].key] + , n, , st[a[i].key] - , -a[i].val};
}
if ( <= st[a[i].key] - )
rec[++ tot] = (Rec){, st[a[i].key] - , , st[a[i].key] - , -a[i].val};
if (ed[a[i].key] + <= n)
rec[++ tot] = (Rec){ed[a[i].key] + , n, ed[a[i].key] + , n, -a[i].val};
}else if (a[i].key == lca){
for(int j = head[a[i].key]; j; j = nxt[j])
if (to[j] != fa[a[i].key][] && LCA(to[j], a[i].chest) == to[j]){
y = to[j];
break;
}
if ( <= st[y] - ) rec[++ tot] = (Rec){, st[y] - , st[a[i].chest], ed[a[i].chest], a[i].val};
if (ed[y] + <= n) rec[++ tot] = (Rec){ed[y] + , n, st[a[i].chest], ed[a[i].chest], a[i].val};
}else if (a[i].chest == lca){
for(int j = head[a[i].chest]; j; j = nxt[j])
if (to[j] != fa[a[i].chest][] && LCA(to[j], a[i].key) == to[j]){
y = to[j];
break;
}
if ( <= st[y] - ) rec[++ tot] = (Rec){st[a[i].key], ed[a[i].key], , st[y] - , a[i].val};
if (ed[y] + <= n) rec[++ tot] = (Rec){st[a[i].key], ed[a[i].key], ed[y] + , n, a[i].val};
}else{
rec[++ tot] = (Rec){st[a[i].key], ed[a[i].key], st[a[i].chest], ed[a[i].chest], a[i].val};
}
// if (rec[tot].x1 == 0) printf("%d %d %d lca = %d\n", a[i].key, a[i].chest, a[i].val, lca);
}
// for(int i = 1; i <= tot; i ++)
// printf("%d %d %d %d %d\n", rec[i].x1, rec[i].x2, rec[i].y1, rec[i].y2, rec[i].val);
int tt = ;
for(int i = ; i <= tot; i ++){
// if (rec[i].x1 == 0 && rec[i].x2 == 0) printf("%d\n", ++ tt);
events[++ num] = (Event){rec[i].x1, rec[i].x2, rec[i].y1, rec[i].val, };
events[++ num] = (Event){rec[i].x1, rec[i].x2, rec[i].y2 + , -rec[i].val, };
}
sort(events + , events + num + );
for(int i = ; i <= num; i ++){
if (events[i].y > events[i - ].y || i == ) ans = max(ans, t[].max);
update(, , n, events[i].l, events[i].r, events[i].val);
if (i == num) ans = max(ans, t[].max);
// printf("%d\n", t[1].max);
}
printf("%d\n", ans + tmp);
}
return ;
}
2017-3-01 test的更多相关文章
- 调试大叔V1.0.1(2017.09.01)|http/s接口调试、数据分析程序员辅助开发神器
2017.09.01 - 调试大叔 V1.0.1*支持http/https协议的get/post调试与反馈:*可保存请求协议的记录:*内置一批动态参数,可应用于URL.页头.参数:*可自由管理cook ...
- Feed back TFS 2017 RC upgrade status to product team in product group 2017.03.01
作为微软的MVP,有一个我最喜欢的好处,就是可以与产品组(产品研发部门)有零距离接触,可以最先拿到即将发版的产品,并且和产品组沟通,对产品中出现的问题实时反馈. 看到TFS产品组吸收了自己的建议和反馈 ...
- Cheatsheet: 2017 03.01 ~ 03.31
Web New Year, New Blog Day 10 - Using JetBrains Rider with a .NET Core Console Application JavaScrip ...
- Work 3(工作类) (2017.07.01)
- ROS机器人程序设计(原书第2版)补充资料 (零) 源代码、资料和印刷错误修订等 2017年01月01日更新
ROS机器人程序设计(原书第2版)补充资料 (零) 源代码等 ROS官网 版)部分内容修订 页:第1行,删去$ 页:第6行,float64 y 前面加一个空格 页:中间创建主题:下面程序不用换行,(& ...
- Cheatsheet: 2017 10.01 ~ 12.31
Mobile Updating Your App for iOS 11 Get Started With Natural Language Processing in iOS 11 Getting S ...
- Cheatsheet: 2017 08.01 ~ 09.30
Golang Building a Worker Pool in Golang A Million WebSockets and Go Writing Plugins in Go imgproxy:R ...
- Cheatsheet: 2017 07.01 ~ 07.31
Other 8 Key Application Performance Metrics & How to Measure Them The Code Review: The Most Impo ...
- Cheatsheet: 2017 06.01 ~ 06.30
.NET Porting a .NET Framework library to .NET Core Performance Improvements in .NET Core High-perfor ...
- Cheatsheet: 2017 05.01 ~05.31
Web Configuring Your .npmrc for an Optimal Node.js Environment Web Developer Security Checklist HTTP ...
随机推荐
- CUDA并行存储模型
CUDA将CPU作为主机(Host),GPU作为设备(Device).一个系统中可以有一个主机和多个设备.CPU负责逻辑性强的事务处理和串行计算,GPU专注于执行高度线程化的并行处理任务.它们拥有相互 ...
- CUDA:Supercomputing for the Masses (用于大量数据的超级计算)-第二节
原文链接 第二节:第一个内核 Rob Farber 是西北太平洋国家实验室(Pacific Northwest National Laboratory)的高级科研人员.他在多个国家级的实验室进行大型并 ...
- MySQL的入门与使用,sqlyog对数据库,表和数据的管理
MySQL的入门 1.到mysql官网下载. 2.安装mysql软件(一定要放到英文路径下) 3.使用 验证是否成功 将mySQL的bin路径添加到系统环境变量Path中 打开dos命令窗口 Wind ...
- linux系统串口编程实例
在嵌入式开发中一些设备如WiFi.蓝牙......都会通过串口进行主机与从机间通信,串口一般以每次1bit位进行传输,效率相对慢. 在linux系统下串口的编程有如下几个步骤,最主要的是串口初始化! ...
- 洛谷P1164小A点菜
这也是一道01背包的题 用的方法比较的巧妙.这个动态规划相当于反过来做的,自己理解就知道了.代码很短 #include<bits/stdc++.h> using namespace std ...
- Java - Java 中的三种 ClassLoader
1.虚拟机类加载器(称为“bootstrap class loader”),它本身没有父类加载器,它负责加载虚拟机的内置类,由于它是用C.C++写的,所以Java无法拿到其class文件,返回的都是空 ...
- 异步解决方案----Promise与Await
前言 异步编程模式在前端开发过程中,显得越来越重要.从最开始的XHR到封装后的Ajax都在试图解决异步编程过程中的问题.随着ES6新标准的到来,处理异步数据流又有了新的方案.我们都知道,在传统的aja ...
- matplotlib(二)——matplotlib控制坐标轴第一个刻度到原点距离
一.问题描述 具体问题是: 用python库matplotlib进行数据的图表展示: 横坐标是自定义统计值: 保存矢量图(svg),保存后发现横坐的第一个点离坐标原点距离较大,导致图形离y轴较远,让画 ...
- mysql索引详细描述与应用场景
索引的数据结构: (1)一般是B+tree:MySql使用最频繁的一个索引数据结构,数据结构以平衡树的形式来组织,因为是树型结构,所以更适合用来处理排序,范围查找等功能. (2)Hash:Hsah索引 ...
- Python操作SQLLite(基本操作)
SQLite 是一个软件库,实现了自给自足的.无服务器的.零配置的.事务性的 SQL 数据库引擎.SQLite 是在世界上最广泛部署的 SQL 数据库引擎.SQLite 源代码不受版权限制. Pyth ...