problem1 link

首先使用两个端点颜色不同的边进行连通。答案是$n-1-m$。其中$m$是联通分量的个数。

problem2 link

首先构造一个最小割的模型。左边的$n_{1}$个点与源点相连,右边的$n_{2}$个点与汇点相连。每个中间点最少有$d+1$条边(有一条到汇点/源点的边)。最小割为$ans$.

假设有$x$个割边出现在源点和$n_{1}$之间,那么$y=ans-x$个出现在$n_{2}$和汇点之间。其中$x,y$应该满足的关系为$0\leq y=ans-x \leq n_{2},0\leq x \leq n_{1},and\leq min(n_{1},n_{2})\rightarrow 0\leq x \leq ans$

左边剩下的$n_{1}-x$个点与右边剩下的$n_{2}-y$个点之间不能有边存在,否则最小割会变大。所以总的边的数量为$f(x)=n_{1}n_{2}-(n_{1}-x)(n_{2}-y)=n_{1}n_{2}-(n_{1}-x)(n_{2}-(ans-x))$

$f(x)$的最大值在$x=\frac{n_{1}-n_{2}+ans}{2}$时取得。

$0 \leq x=\frac{n_{1}-n_{2}+ans}{2} \leq ans\rightarrow -ans\leq n_{1}-n_{2}\leq ans$。当$n_{1}-n_{2}$不在这个范围时,枚举边界即可。

problem3 link

如果两个数字$x,y$的差$x-y$能被数$p$整除,那么有$x\equiv y(mod(p))$。

所以可以对每个素数计算有那些数对$(A_{i},B_{j})$的余数相等,他们的差值就含有素数$p$。最后就剩下那些素数特别大的。

这个题目应该有几组特别刁钻的测试数据,代码一直超时。

code for problem1

#include <vector>

class ChristmasTreeDecoration {
public:
int solve(const std::vector<int> &col, const std::vector<int> &x,
const std::vector<int> &y) {
int n = static_cast<int>(col.size());
int m = static_cast<int>(x.size());
father_.resize(n);
for (int i = 0; i < n; ++i) {
father_[i] = i;
}
int number = 0;
for (int i = 0; i < m; ++i) {
int u = x[i] - 1;
int v = y[i] - 1;
if (col[u] != col[v]) {
int pu = GetRoot(u);
int pv = GetRoot(v);
if (pu != pv) {
father_[pu] = pv;
++number;
}
}
}
return n - 1 - number;
} private:
int GetRoot(int x) {
if (father_[x] == x) {
return x;
}
return father_[x] = GetRoot(father_[x]);
} std::vector<int> father_;
};

code for problem2

#include <algorithm>

class MaximumBipartiteMatchingProblem {
public:
long long solve(int n1, int n2, int ans, int d) {
long long result = -1;
auto Update = [&](int x) {
if (x < d || ans - x < d) {
return;
}
result = std::max(result, 1ll * n2 * x + 1ll * (n1 - x) * (ans - x)); }; if (n1 > n2) {
std::swap(n1, n2);
}
if (n1 == ans) {
return 1ll * n1 * n2;
}
Update(0);
Update(d);
Update(ans - d);
Update(n1);
Update(n2);
Update((ans + n1 - n2) / 2);
Update((ans + n1 - n2) / 2 + 1);
return result;
}
};

code for problem3

#include <algorithm>
#include <vector> constexpr int kMax = 1000;
constexpr int kMaxPrime = 31622; int diff[kMax][kMax];
int values[kMax][kMax]; int nxt[kMax];
int head[kMaxPrime];
int tag[kMaxPrime]; int prime_tag[kMaxPrime]; class TwoNumberGroups {
static constexpr int kMod = 1000000007; public:
int solve(const std::vector<int> &A, const std::vector<int> &numA,
const std::vector<int> &B, const std::vector<int> &numB) {
int n = static_cast<int>(A.size());
int m = static_cast<int>(B.size());
for (int i = 0; i < n; ++i) {
for (int j = 0; j < m; ++j) {
diff[i][j] = std::abs(A[i] - B[j]);
}
}
int result = 0;
for (int p = 2; p < kMaxPrime; ++p) {
if (prime_tag[p] != 1) {
for (int x = p + p; x < kMaxPrime; x += p) {
prime_tag[x] = 1;
}
for (int i = 0; i < n; ++i) {
int t = A[i] % p;
if (tag[t] != p) {
head[t] = -1;
tag[t] = p;
}
nxt[i] = head[t];
head[t] = i;
}
for (int i = 0; i < m; ++i) {
int t = B[i] % p;
if (tag[t] == p) {
for (int j = head[t]; j != -1; j = nxt[j]) {
if (A[j] != B[i]) {
values[j][i] += p;
while (diff[j][i] % p == 0) {
diff[j][i] /= p;
}
}
}
}
}
}
}
for (int i = 0; i < n; ++i) {
for (int j = 0; j < m; ++j) {
if (diff[i][j] > 1) {
values[i][j] += diff[i][j];
}
result += 1ll * numA[i] * numB[j] % kMod * values[i][j] % kMod;
if (result >= kMod) {
result -= kMod;
}
}
}
return result;
}
};

topcoder srm 640 div1的更多相关文章

  1. Topcoder SRM 643 Div1 250<peter_pan>

    Topcoder SRM 643 Div1 250 Problem 给一个整数N,再给一个vector<long long>v; N可以表示成若干个素数的乘积,N=p0*p1*p2*... ...

  2. Topcoder Srm 726 Div1 Hard

    Topcoder Srm 726 Div1 Hard 解题思路: 问题可以看做一个二分图,左边一个点向右边一段区间连边,匹配了左边一个点就能获得对应的权值,最大化所得到的权值的和. 然后可以证明一个结 ...

  3. topcoder srm 714 div1

    problem1 link 倒着想.每次添加一个右括号再添加一个左括号,直到还原.那么每次的右括号的选择范围为当前左括号后面的右括号减去后面已经使用的右括号. problem2 link 令$h(x) ...

  4. topcoder srm 738 div1 FindThePerfectTriangle(枚举)

    Problem Statement      You are given the ints perimeter and area. Your task is to find a triangle wi ...

  5. Topcoder SRM 602 div1题解

    打卡- Easy(250pts): 题目大意:rating2200及以上和2200以下的颜色是不一样的(我就是属于那个颜色比较菜的),有个人初始rating为X,然后每一场比赛他的rating如果增加 ...

  6. Topcoder SRM 627 div1 HappyLettersDiv1 : 字符串

    Problem Statement      The Happy Letter game is played as follows: At the beginning, several players ...

  7. Topcoder SRM 584 DIV1 600

    思路太繁琐了 ,实在不想解释了 代码: #include<iostream> #include<cstdio> #include<string> #include& ...

  8. TopCoder SRM 605 DIV1

    604的题解还没有写出来呢.先上605的. 代码去practice房间找. 说思路. A: 贪心,对于每个类型的正值求和,如果没有正值就取最大值,按着求出的值排序,枚举选多少个类型. B: 很明显是d ...

  9. topcoder srm 575 div1

    problem1 link 如果$k$是先手必胜那么$f(k)=1$否则$f(k)=0$ 通过对前面小的数字的计算可以发现:(1)$f(2k+1)=0$,(2)$f(2^{2k+1})=0$,(3)其 ...

随机推荐

  1. CentOS7 FTP安装与配置

    1.FTP的安装 #安装yum install -y vsftpd #设置开机启动systemctl enable vsftpd.service #启动systemctl start vsftpd.s ...

  2. TypeScript初探

    TypeScript初探 TypeScript什么? 官方给的定义:TypeScript是一种由微软开发的自由和开源的编程语言,它是JavaScript类型的超集,可以编译成纯JavaScript,本 ...

  3. 关于ico图标

    ico图标可以作为网页标签上显示的小logo,比如: 要获取一个网站的ico图标,只需要在url后输入/favicon.ico即可,比如   https://www.baidu.com/favicon ...

  4. Python_tkinter(5)_GUI工具

    1.Excel行数统计工具 源代码 import xlrd import tkinter as tk import tkinter.filedialog # 计算一个工作簿中所有Sheet表的行数 d ...

  5. 微信小程序登录流程及解析用户openid session_key,获取用户信息

    为优化用户体验,使用 wx.getUserInfo 接口直接弹出授权框的开发方式将逐步不再支持.从2018年4月30日开始,小程序与小游戏的体验版.开发版调用 wx.getUserInfo 接口,将无 ...

  6. 给opencart产品页添加额外信息

    有时我们在开发opencart时需要给产品页添加一些额外的信息,第一种聪明的方法可以修改并调用已有字段,详细可以参考opencart3产品页调用upc/数量等信息:如果您的开发能力不错的话可以用第二种 ...

  7. ThinkPhp3.2.3 使用phpExcel导入数据

    public function uploadExcel(){ if (!empty($_FILES)){ $upload = new \Think\Upload(); // 实例化上传类 $uploa ...

  8. webpack(5) -开发环境

    使用 source map (仅用于开发环境) 当 webpack 打包源代码时,可能会很难追踪到 error(错误) 和 warning(警告) 在源代码中的原始位置.例如,如果将三个源文件(a.j ...

  9. jenkins centos slave起不来报错The SSH key presented by the remote host does not match the key saved in the Known Hosts file against this host. Connections to this host will be denied until the two keys mat

    场景:我的centos-204是一台centos的机器,本来用https://www.cnblogs.com/zndxall/p/8297356.html 的centos slave方式搭建ok的,一 ...

  10. layer倒计时弹框/弹层 DEMO

    layer.msg("提示语...", { time: 5000, shade: 0.6, success: function (layero, index) { var msg ...