2018 CCPC网络赛

Buy and Resell

题目描述:有一种物品,在\(n\)个地点的价格为\(a_i\),现在一次经过这\(n\)个地点,在每个地点可以买一个这样的物品,也可以卖出一个物品,问最终赚的钱的最大值。

solution

用两个堆来维护,一个堆维护已经找到卖家的,一个堆维护还没找到卖家的。

对于第\(i\)个地点,在已经找到卖家的堆里找出卖的钱的最小值,如果最小值小于\(a_i\),则将卖家换成\(i\),然后将原来的卖家放到没找到卖家的那里;如果最小值对于\(a_i\),那就在还没找到卖家的那里找出最小值,然后跟\(i\)配对放到已经找到卖家那个堆。

其实第二个不用堆存也可以,因为它肯定是递减的,所以用栈即可。

时间复杂度:\(O(nlogn)\)

Congruence equation

Dream

题目描述:重新定义\(p\)以内的数互相相加的和以及互相相乘的积,使得\(\forall m, n<p, (m+n)^p=m^p+n^p\)

solution

二项式定理展开,将组合数写成阶乘的形式,发现中间每个组合数都是\(p\)的倍数,因此只要将加法和乘法定义成模\(p\)意义下的答案即可。

时间复杂度:\(O(p^2)\)

Find Integer

题目描述:给定\(n, a\), 求\(a^n+b^n=c^n\)的一个解,或无解。

solution

根据费马定理,\(n>2\)时无解,当\(n=2\)时,若\(a=2n\),则\((2n^2-1)^2+a^2=(2n^2+1)^2\)

若\(a=2n+1\),则\((2n^2)^2+a^2=(2n^2+1)^2\)

时间复杂度:\(O(1)\)

GuGu Convolution

题目描述

solution

题目等价于求

\[n!\sum_{i=0 (n-i)为奇数}^{n} \frac{1}{i!(n-i)!}A^i \sqrt{B}^{n-i}
\]

整理一下

\[\sum_{i=0 (n-i)为奇数}^{n} C_n^iA^i \sqrt{B}^{n-i}
\]

如果不管\((n-i)\)为奇数,则原式等于\((A+\sqrt{B})^n\),因为只取\((n-i)\)为奇数的结果,相当于是求\(\sqrt{B}\)的系数,因此用一个快速幂来求解即可。

时间复杂度:\(O(logn)\)

Neko's loop

题目描述:有一个环,上面有\(n\)个点,每个点有一个权值\(a_i\)。选择一个点当作出发点,每移动一次向前跳\(k\)个点,每经过一个点可以得到该点的权值(可重复),问最多经过\(m\)个点时,得到总权值的最大值。

solution

原图被分成了\(gcd(n, k)\)个环,如果环是正环,则尽量走整个环走,只剩下最后一个整环和剩余的步数(假设为\(rest\)),然后把环复制两次,求前缀和,用单调队列求出长度不超过\(rest\)的区间的和的最大值。

时间复杂度:\(O(n)\)

Search for Answer

题目描述:给定一个竞赛图,有些边的方向需要确定,确定后,计算图对应的一个价值:对于图中的四个点,如果它们按顺序指向下一个点,则答案加一,若指向是交替的,则答案减一,求答案的最大值。

solution

对于四个点,有以下三种情况:

  1. 按顺序指向下一个点,则每个点的出度都是\(1\)
  2. 指向交替,则有两个点的出度为\(2\)
  3. 其它情况,有一个点的出度为\(2\)

先假设所有的点的四元组都是按顺序指向下一个点的,则答案为\(A_n^4\),对于度大于等于\(2\)的点,从中选择两个点作为它指向的点,然后随便再找一个点凑成一个四元组,这样有\(A_{deg}^{2}(n-3)\)中选择,这种情况是会使答案不能加一的,如果同一个四元组被选择了两次,就相当于是第二种情况,会使答案减一,所以最后的答案为\(A_n^4-\sum A_{deg}^2(n-3)*4\)(\(4\)为一个点在四元组中有\(4\)个位置可以选,一旦选了,其它的点的位置就确定了)

后边的部分可以用费用流来求,可以对\(C_{deg}^2\)进行差分,每差分一次建一条新边,费用为差分出来的值,又因为差分的值是递增的,所以就能计算\(C_{deg}^2\)的值。

时间复杂度:\(O(费用流)\)

#include <bits/stdc++.h>
using namespace std; const int maxn=205;
const int inf=0x3fffffff; struct LINK
{
int id, next, flow, cost;
}; int n, now, TT;
int ans;
int degree[maxn], cnt[maxn];
int h[maxn*2];
LINK t[maxn*maxn*8];
int f[maxn*2], fa[maxn*2], q[maxn*2];
bool vis[maxn*2]; void join(int u, int v, int fl, int c)
{
t[now].id=v; t[now].next=h[u]; t[now].cost=c; t[now].flow=fl; h[u]=now++;
t[now].id=u; t[now].next=h[v]; t[now].cost=-c; t[now].flow=0; h[v]=now++;
}
void build()
{
scanf("%d", &n);
now=0;
for (int i=0; i<=n; ++i)
{
h[i]=-1;
degree[i]=cnt[i]=0;
}
TT=n;
for (int i=1; i<=n; ++i)
for (int j=1; j<=n; ++j)
{
int d;
scanf("%1d", &d);
if (d==1) ++degree[j];
else if (d==2 && i<j)
{
++cnt[i];
++cnt[j];
h[++TT]=-1;
join(TT, i, 1, 0);
join(TT, j, 1, 0);
}
}
for (int i=n+1; i<=TT; ++i) join(0, i, 1, 0);
h[++TT]=-1;
ans=0;
for (int i=1; i<=n; ++i)
{
ans+=degree[i]*(degree[i]-1)/2;
for (int j=1; j<=cnt[i]; ++j)
join(i, TT, 1, degree[i]+j-1);
}
}
bool SPFA()
{
int head=0, tail=0;
for (int i=0; i<=TT; ++i)
{
vis[i]=false;
f[i]=inf;
fa[i]=-1;
}
q[0]=0;
f[0]=0;
while (head<=tail)
{
int cur=q[(head++)%(TT+1)];
vis[cur]=false;
for (int i=h[cur]; i>-1; i=t[i].next)
if (t[i].flow && f[cur]+t[i].cost<f[t[i].id])
{
f[t[i].id]=f[cur]+t[i].cost;
fa[t[i].id]=i;
if (!vis[t[i].id])
{
vis[t[i].id]=true;
q[(++tail)%(TT+1)]=t[i].id;
}
}
}
return (f[TT]<inf);
}
void modify()
{
ans+=f[TT];
int cur=TT;
while (cur)
{
t[fa[cur]].flow--;
t[fa[cur]^1].flow++;
cur=t[fa[cur]^1].id;
}
}
void solve()
{
while (SPFA()) modify();
ans=n*(n-1)*(n-2)*(n-3)-ans*(n-3)*8;
printf("%d\n", ans);
}
int main()
{
int casesum;
scanf("%d", &casesum);
while (casesum--)
{
build();
solve();
}
return 0;
}

Tree and Permutation

题目描述:给定一个树,有\(n\)个点,对于每一个\(n\)排列,求出排列中相邻两个数在树上的距离的和,作为排列的值,求所有排列的值的和。

solution

可知每个数对在所有排列中共出现\((n-1)!\)次,所以每个数对的距离贡献了\((n-1)!\)次。问题转化为求树上两两之间的距离的和。可以算出每条边对答案的贡献,贡献为这条边分割的两部分互相配对形成的点对数。

时间复杂度:\(O(n)\)

YJJ's Salesman

题目描述:在一个二维平面,有一些点\((x, y)\)拥有开心值,当从\((x-1, y-1)\)走到\((x, y)\)时,就能拿到这个点的开心值,现在从原点出发,每次只能从\((x, y)\)走到\((x+1, y), (x, y+1), (x+1, y+1)\),问能获得的总的开心值的最大值。

solution

\(dp\),按\(x\)坐标对点排序,从小到大进行\(dp\),\(y\)坐标用树状数组维护对应的最大值。

时间复杂度:\(O(nlogn)\)

2018 CCPC网络赛的更多相关文章

  1. 2018 CCPC网络赛 几道数学题

    1002 Congruence equation 题目链接  : http://acm.hdu.edu.cn/showproblem.php?pid=6439 题解 : https://www.zyb ...

  2. 2018 CCPC网络赛 hdu6444 Neko's loop

    题目描述: Neko has a loop of size n.The loop has a happy value ai on the i−th(0≤i≤n−1) grid. Neko likes ...

  3. 2018 CCPC 网络赛 Buy and Resell

    The Power Cube is used as a stash of Exotic Power. There are n cities numbered 1,2,…,n where allowed ...

  4. 2018 CCPC网络赛 1010 hdu 6447 ( 树状数组优化dp)

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=6447 思路:很容易推得dp转移公式:dp[i][j] = max(dp[i][j-1],dp[i-1][j ...

  5. 【2018 CCPC网络赛 1004】Find Integer(勾股数+费马大定理)

    Problem Description people in USSS love math very much, and there is a famous math problem . give yo ...

  6. 【2018 CCPC网络赛】1001 - 优先队列&贪心

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=6438 获得最大的利润,将元素依次入栈,期中只要碰到比队顶元素大的,就吧队顶元素卖出去,答案加上他们期中 ...

  7. 【2018 CCPC网络赛】1009 - 树

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=6446 题目给出的数据为一棵树,dfs扫描每条边,假设去掉某条边,则左边 x 个点,右边 n-x 个点, ...

  8. 【2018 CCPC网络赛】1003 - 费马小定理

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=6440 这题主要是理解题意: 题意:定义一个加法和乘法,使得 (m+n)p = mp+np; 其中给定 ...

  9. 【2018 CCPC网络赛】1004 - 费马大定理&数学

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=6441 Knowledge Point: 1. 费马大定理:当整数n >2时,关于x, y, z的 ...

随机推荐

  1. Common Substrings POJ - 3415(长度不小于k的公共子串的个数)

    题意: 给定两个字符串A 和 B, 求长度不小于 k 的公共子串的个数(可以相同) 分两部分求和sa[i-1] > len1  sa[i] < len1  和  sa[i-1] < ...

  2. 【转】关于在linux下清屏的几种技巧

    在windows的DOS操作界面里面,清屏的命令是cls,那么在linux 里面的清屏命令是什么呢?下面笔者分享几种在linux下用过的清屏方法. 1.clear命令.这个命令将会刷新屏幕,本质上只是 ...

  3. python之插入排序

    插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的.个数加一的有序数据,算法适用于少量数据的排序,时间复杂度为O(n^2).是稳定的排序方法.插入算法把要排序的数组分成两部 ...

  4. POJ.2763 Housewife Wind ( 边权树链剖分 线段树维护区间和 )

    POJ.2763 Housewife Wind ( 边权树链剖分 线段树维护区间和 ) 题意分析 给出n个点,m个询问,和当前位置pos. 先给出n-1条边,u->v以及边权w. 然后有m个询问 ...

  5. Android Studio 使用VCS版本控制

    1.SVN的配置: 如果项目使用的是SVN配置,那么除了乌龟SVN GUI工具外,你还得下载Subversion, 因为AS要用其中的xx.exe命令行执行程序, 下载地址:https://www.v ...

  6. NTT+多项式求逆

    #include<iostream> #include<cstdio> #include<algorithm> #include<cstring> #i ...

  7. 团体程序设计天梯赛-练习集 L1-031. 到底是不是太胖了

    比较两个实型的数: 若两者相等,也许用a>/b会出错... 我又想到了codeforces有很多这样的坑... #include <stdio.h> #include <std ...

  8. echarts分组柱状图的前后台处理 带平均线显示

    原生的echarts使用: <!DOCTYPE html> <html> <head> <meta charset="utf-8" /&g ...

  9. 装饰器 and 闭包函数 未完。。。。。

    装饰器是一个返回函数的高阶函数.装饰器=高阶函数+函数嵌套+闭包 装饰器需要遵循的原则:不修改被装饰函数的源代码,不修改被装饰函数的调用方式. 高阶函数 1.函数接收的参数是一个函数名 2.函数的返回 ...

  10. 「Vue」vue cli3中axios的基本用法

    1.安装axiosnpm i axios -S2.main.js中设置import axios from 'axios'Vue.prototype.$axios = axiosPS:这里有个小坑,ax ...