三道好像都是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的更多相关文章

  1. 调试大叔V1.0.1(2017.09.01)|http/s接口调试、数据分析程序员辅助开发神器

    2017.09.01 - 调试大叔 V1.0.1*支持http/https协议的get/post调试与反馈:*可保存请求协议的记录:*内置一批动态参数,可应用于URL.页头.参数:*可自由管理cook ...

  2. Feed back TFS 2017 RC upgrade status to product team in product group 2017.03.01

    作为微软的MVP,有一个我最喜欢的好处,就是可以与产品组(产品研发部门)有零距离接触,可以最先拿到即将发版的产品,并且和产品组沟通,对产品中出现的问题实时反馈. 看到TFS产品组吸收了自己的建议和反馈 ...

  3. Cheatsheet: 2017 03.01 ~ 03.31

    Web New Year, New Blog Day 10 - Using JetBrains Rider with a .NET Core Console Application JavaScrip ...

  4. Work 3(工作类) (2017.07.01)

  5. ROS机器人程序设计(原书第2版)补充资料 (零) 源代码、资料和印刷错误修订等 2017年01月01日更新

    ROS机器人程序设计(原书第2版)补充资料 (零) 源代码等 ROS官网 版)部分内容修订 页:第1行,删去$ 页:第6行,float64 y 前面加一个空格 页:中间创建主题:下面程序不用换行,(& ...

  6. Cheatsheet: 2017 10.01 ~ 12.31

    Mobile Updating Your App for iOS 11 Get Started With Natural Language Processing in iOS 11 Getting S ...

  7. Cheatsheet: 2017 08.01 ~ 09.30

    Golang Building a Worker Pool in Golang A Million WebSockets and Go Writing Plugins in Go imgproxy:R ...

  8. Cheatsheet: 2017 07.01 ~ 07.31

    Other 8 Key Application Performance Metrics & How to Measure Them The Code Review: The Most Impo ...

  9. Cheatsheet: 2017 06.01 ~ 06.30

    .NET Porting a .NET Framework library to .NET Core Performance Improvements in .NET Core High-perfor ...

  10. Cheatsheet: 2017 05.01 ~05.31

    Web Configuring Your .npmrc for an Optimal Node.js Environment Web Developer Security Checklist HTTP ...

随机推荐

  1. python读取图像

    from PIL import Imageimg = Image.open('/Users/NaCl/Desktop/test.png')img.show()

  2. 理解dropout

    理解dropout 注意:图片都在github上放着,如果刷不开的话,可以考虑FQ. 转载请注明:http://blog.csdn.net/stdcoutzyx/article/details/490 ...

  3. 8--oop

    oop-Python面向对象 Python的面向对象 面向对象编程 基础 共有私有 继承 组合,Mixin 魔法函数 魔法函数概述 构造类魔法函数 运算类魔法函数 1.面向对象概述(ObjectOri ...

  4. 两级宏&&字符串化宏

    如果你想字符串化宏参数扩展的结果,你必须使用两个级别的宏. #define xstr(s) str(s) #define str(s) #s #define foo 4 str (foo) ==> ...

  5. java基础编程——获取栈中的最小元素

    题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1)).   题目代码 /** * Created by YuKai Fan on 2018/9 ...

  6. vue 服务代理 调用第三方api

    项目中前期需要调用第三方API来获取汇率.因为直接调用会有跨域的问题,所以使用来服务代理. 在config配置代理可以这样写: 而调用接口就可以这样写: 坑:配置完成后一直报500,开始怀疑人生.最后 ...

  7. 2.3.3 zerosum 和为零

    #include<bits/stdc++.h> using namespace std; ],a; ]={' ','+','-'}; void out() { ;i<a;i++) c ...

  8. java中equals和==的区别详解

    java中的数据类型,可分为两类: 1.基本数据类型. byte,short,char,int,long,float,double,boolean这八大原始数据类型他们之间的比较,使用“==”,比较的 ...

  9. 第二章JavaScript 函数和对象

    1 JavaScript 函数 1.1 声明函数的方式 function 关键字 匿名函数方式(表达式方式) Function 构造函数方式 1.2 参数问题 形参和实参数量问题 可选形参(参数默认值 ...

  10. 关于js中onclick字符串传参问题(html="")

    规则: 外变是“”,里面就是‘’外边是‘’,里边就是“”   示例: var a="111"; var html="<a onclick='selecthoods( ...