topcoder srm 455 div1
problem1 link
令$f[x1][y1][x2][y2]$表示矩形(x1,y1)(x2,y2)中能选出的最大值。dp即可。
problem2 link
这个题应该有更好的递推公式。
我的做法是这样的。设$f[i]$表示$i$时的答案,令$g[i]=f[i]-f[i-1]$。通过暴力计算$g$的前几项,发现$g$的公式为
$g(n+2)=a(n)=\frac{(2n+3)*(6n^4+36n^3+76n^2+66n+5)}{960}-\frac{(-1)^n}{64}$
problem3 link
由于对于一个节点,其对于某一种tree只能选择至多一次,因此可以对每种tree依次进行处理。
对于tree的某一种,找到target中与其同构的所有子树,然后进行dp即可。 设$f[mask]$将$mask$对应的边反转的最小代价。
code for problem1
import java.util.*;
import java.math.*;
import static java.lang.Math.*; public class DonutsOnTheGridEasy { public int calc(String[] grid) {
final int n = grid.length;
final int m = grid[0].length();
if (n < 3 || m < 3) {
return 0;
}
int[][] h = new int[n + 1][m + 1];
int[][] v = new int[n + 1][m + 1];
for (int i = 0; i < n; ++i) {
for (int j = 0; j < m; ++j) {
h[i + 1][j + 1] = h[i + 1][j];
if (grid[i].charAt(j) == '0') {
h[i + 1][j + 1] += 1;
}
}
}
for (int j = 0; j < m; ++j) {
for (int i = 0; i < n; ++i) {
v[i + 1][j + 1] = v[i][j + 1];
if (grid[i].charAt(j) == '0') {
v[i + 1][j + 1] += 1;
}
}
}
int[][][][] f = new int[n + 1][m + 1][n + 1][m + 1];
for (int height = 3; height <= n; ++ height) {
for (int width = 3; width <= m; ++ width) {
for (int i = 1; i + height -1 <= n; ++ i) {
for (int j = 1; j + width -1 <= m; ++ j) {
int i1 = i + height - 1;
int j1 = j + width -1; f[i][j][i1][j1]= Math.max(f[i][j][i1][j1], f[i + 1][j][i1][j1]);
f[i][j][i1][j1]= Math.max(f[i][j][i1][j1], f[i][j][i1 - 1][j1]);
f[i][j][i1][j1]= Math.max(f[i][j][i1][j1], f[i][j + 1][i1][j1]);
f[i][j][i1][j1]= Math.max(f[i][j][i1][j1], f[i][j][i1][j1 - 1]); if (!check(i, j, i1, j1, h, v)) {
continue;
}
f[i][j][i1][j1]= Math.max(f[i][j][i1][j1], f[i + 1][j + 1][i1 - 1][j1 - 1] + 1);
}
}
}
}
return f[1][1][n][m];
} boolean check(int x1, int y1, int x2, int y2, int[][] h, int[][] v) {
return h[x1][y2] - h[x1][y1 - 1] == y2 - y1 + 1
&& h[x2][y2] - h[x2][y1 - 1] == y2 - y1 + 1
&& v[x2][y1] - v[x1 - 1][y1] == x2 - x1 + 1
&& v[x2][y2] - v[x1 - 1][y2] == x2 - x1 + 1;
}
}
code for problem2
import java.util.*;
import java.math.*;
import static java.lang.Math.*; public class ConvexHexagons { final static int mod = 1000000007;
final static long rev960 = pow(960, mod - 2);
final static long rev64 = pow(64, mod - 2); public int find(int N) {
if (N < 3) {
return 0;
}
int ans = 0;
for (int i = 3; i <= N; ++i) {
ans += cal(i - 2);
ans %= mod;
}
return ans;
} static long pow(long a, long b) {
a %= mod;
long ans = 1;
while (b > 0) {
if (1 == (b & 1)) {
ans = ans * a % mod;
}
a = a * a % mod;
b >>= 1;
}
return ans;
} long cal(long n) {
long A = (2 * n + 3) % mod;
long B = (6 * pow(n, 4) + 36 * pow(n, 3) + 76 * pow(n, 2) + 66 * n + 5) % mod;
long ans = A * B % mod * rev960 % mod;
if (1 == (n & 1)) {
ans += rev64;
}
else {
ans -= rev64;
}
ans %= mod;
if (ans < 0) {
ans += mod;
}
return ans;
} }
code for problem3
import java.util.*;
public class ActivateTree {
List<Edge> alledges = null;
List<Edge> currentTree = null;
List<List<Integer>> mask = new ArrayList<>();
boolean[] visited = null;
public int minCost(String[] trees, String target, int[] costs) {
alledges = getEdges(target);
int n = 0;
for (int i = 0; i < alledges.size(); ++ i) {
n = Math.max(n, alledges.get(i).x + 1);
n = Math.max(n, alledges.get(i).y + 1);
}
for (int i = 0; i < n; ++ i) {
mask.add(new ArrayList<>());
}
final int m = alledges.size();
int[][] f = new int[2][1 << m];
Arrays.fill(f[0], -1);
visited = new boolean[m];
f[0][0] = 0;
for (int i = 0; i < trees.length; ++ i) {
currentTree = getEdges(trees[i]);
for (int j = 0; j < n; ++ j) {
mask.get(j).clear();
}
dfs(0, new int[currentTree.size()]);
for (int u = 0; u < n; ++ u) {
for (int j = 0; j < (1 << m); ++ j) {
f[1][j] = f[0][j];
}
for (int s = 0; s < (1 << m); ++ s) {
for (int t: mask.get(u)) {
if (f[1][s ^ t] != -1) {
if (f[0][s] == -1 || f[0][s] > f[1][s ^ t] + costs[i]) {
f[0][s] = f[1][s ^ t] + costs[i];
}
}
}
}
}
}
return f[0][(1 << m) - 1];
}
Map<Integer,Integer> map0 = new HashMap<>();
Map<Integer,Integer> map1 = new HashMap<>();
void dfs(int id, int[] ch) {
if (id == currentTree.size()) {
int st = 0;
for (int i : ch) {
st |= 1 << i;
}
int rt = alledges.get(ch[0]).x;
while (true) {
boolean tag = false;
for (int i = 0; i < ch.length; ++ i) {
if (alledges.get(ch[i]).y == rt) {
rt = alledges.get(ch[i]).x;
tag = true;
break;
}
}
if (!tag) {
break;
}
}
if (mask.get(rt).contains(st)) {
return;
}
map0.clear();
map1.clear();
for (int i = 0; i < ch.length; ++ i) {
int x = alledges.get(ch[i]).x;
int y = alledges.get(ch[i]).y;
int xx = currentTree.get(i).x;
int yy = currentTree.get(i).y;
for (int j = 0; j < 2; ++ j) {
int u = (j == 0)? x : y;
int v = (j == 0)? xx : yy;
if (map0.containsKey(u)) {
if (map0.get(u) != v) {
return;
}
if (!map1.containsKey(v) || map1.get(v) != u) {
return;
}
}
else {
if (map1.containsKey(v)) {
return;
}
map0.put(u, v);
map1.put(v, u);
}
}
}
mask.get(rt).add(st);
return;
}
for (int i = 0; i < alledges.size(); ++ i) {
if (!visited[i]) {
visited[i] = true;
ch[id] = i;
dfs(id + 1, ch);
visited[i] = false;
}
}
}
static List<Edge> getEdges(String target) {
List<Edge> result = new ArrayList<>();
String[] all = target.split("\\s+");
for (int i = 1; i < all.length; ++ i) {
int p = Integer.valueOf(all[i]);
result.add(new Edge(p, i));
}
return result;
}
static class Edge {
int x, y;
Edge() {}
Edge(int x, int y) {
this.x = x;
this.y = y;
}
}
}
topcoder srm 455 div1的更多相关文章
- Topcoder SRM 643 Div1 250<peter_pan>
Topcoder SRM 643 Div1 250 Problem 给一个整数N,再给一个vector<long long>v; N可以表示成若干个素数的乘积,N=p0*p1*p2*... ...
- Topcoder Srm 726 Div1 Hard
Topcoder Srm 726 Div1 Hard 解题思路: 问题可以看做一个二分图,左边一个点向右边一段区间连边,匹配了左边一个点就能获得对应的权值,最大化所得到的权值的和. 然后可以证明一个结 ...
- topcoder srm 714 div1
problem1 link 倒着想.每次添加一个右括号再添加一个左括号,直到还原.那么每次的右括号的选择范围为当前左括号后面的右括号减去后面已经使用的右括号. problem2 link 令$h(x) ...
- topcoder srm 738 div1 FindThePerfectTriangle(枚举)
Problem Statement You are given the ints perimeter and area. Your task is to find a triangle wi ...
- Topcoder SRM 602 div1题解
打卡- Easy(250pts): 题目大意:rating2200及以上和2200以下的颜色是不一样的(我就是属于那个颜色比较菜的),有个人初始rating为X,然后每一场比赛他的rating如果增加 ...
- Topcoder SRM 627 div1 HappyLettersDiv1 : 字符串
Problem Statement The Happy Letter game is played as follows: At the beginning, several players ...
- Topcoder SRM 584 DIV1 600
思路太繁琐了 ,实在不想解释了 代码: #include<iostream> #include<cstdio> #include<string> #include& ...
- TopCoder SRM 605 DIV1
604的题解还没有写出来呢.先上605的. 代码去practice房间找. 说思路. A: 贪心,对于每个类型的正值求和,如果没有正值就取最大值,按着求出的值排序,枚举选多少个类型. B: 很明显是d ...
- 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)其 ...
随机推荐
- gitlab数据迁移至其他gitlb服务器上
需求: A : 待迁移服务器,上边存有数据 B:接收项目得服务器,本身存在数据 验证方案: 一,搭建gitlab8.15.2 OS:rhel7.4 yum install policycoreutil ...
- linux临时网络配置
1.设置IP地址: ifconfig ens33 192.168.60.231/24 2.添加默认网关路由 $Route add default gw <默认网关地址> 例:#route ...
- git起步
关于版本控制 什么是版本控制?为什么要版本控制? 版本控制是记录文件内容变化,以便在将来查阅特定版本的系统.有了版本控制,我们就可以将某个文件或是整个项目回退到之前的某个时间段,查看现在和之前相比项目 ...
- 水题T,二进制转16进制
输入一个2进制的数,要求输出该2进制数的16进制表示. 在16进制的表示中,A-F表示10-15 Input第1行是测试数据的组数n,后面跟着n行输入.每组测试数据占1行,包括一个以0和1组成的字符串 ...
- 回声状态网络(ESN)基础教程
http://jlearning.cn/2017/05/29/ESN-basic-tutorial/ 最近在看回声状态网络(Echo State Network)的内容,注意到中文搜索引擎搜不到关于有 ...
- Sitecore CMS中配置项目图标
在Sitecore中,图标通常用于通过各种不同的模板类型快速区分项目.文章可能使用红色图标,而列表页面可能使用蓝色.项目上设置的图标可以在内容树中看到,也可以在选择项目时在内容编辑器的顶部看到. 从功 ...
- scu 4444 Travel
题意: 一个完全图,有n个点,其中m条边是权值为a的无向边,其它是权值为b的无向边,问从1到n的最短路. 思路: 首先判断1和n被哪种边连通. 如果是被a连通,那么就需要全部走b的边到达n,选择最小的 ...
- HOG基本原理
图像识别,图像预处理,HOG算法介绍. 转自: https://blog.csdn.net/gy429476195/article/details/50156813
- 问题 1084: 用筛法求之N内的素数。
#include <iostream> #include <cstdio> #include <cstring> #include <string> # ...
- MVC模式、加密、jsonwebtoken
一.MVC模式(架构思想) M:model层,主要是数据的增删改查 V:view层,主要是视图的展示 C:controller层,主要负责业务逻辑 二.加密(md5加密.sha256加密)1.sha2 ...