problem1 link

遍历未被删除的叶子结点即可。

problem2 link

首先,将所有的蛋白质原子编号,设为$[0,m-1]$,每个原子可能对应多个长度为3的$ACGT$。设$n$为DNA串的长度。用$g[i][j]$表示从$i$开始匹配数字$j$后的最小位置,$0\leq i \leq n-1,0\leq j \leq m-1$。

然后就是动态规划.设$dp[i][j]$表示位置$i$之前最后匹配的数字为$j$的方案数。对所有的$0\leq t < m$有$dp[g[i][t]][t]+=dp[i][j] $

problem3 link

首先将所有节点分成若干个$group$,每个$group$里的节点可以互相到达。然后一个一个$group$进行处理。

对于某个$group$,建一个新的二分图$G$。对于其中的一个点$x$,若存在不在该$group$中的一点$y$使得存在边$y$到$x$那么在新图$G$中连一条$x$到$y$的边。那么该$group$中需要作为新的$division$的根结点的个数为$|group|-maxMatch(G)$。

code for problem1

import java.util.*;
import java.math.*;
import static java.lang.Math.*; public class CellRemoval { List<List<Integer>> lists=null; public int cellsLeft(int[] parent, int deletedCell) {
final int n=parent.length;
lists=new ArrayList<>();
for(int i=0;i<n;++i) {
lists.add(new ArrayList<>());
}
int root=-1;
for(int i=0;i<n;++i) {
if(parent[i]==-1) {
root=i;
}
else {
lists.get(parent[i]).add(i);
}
}
return dfs(root,deletedCell);
} int dfs(int u,int d) {
if(u==d) {
return 0;
}
if(lists.get(u).size()==0) {
return 1;
}
int result=0;
for(int i=0;i<lists.get(u).size();++i) {
result+=dfs(lists.get(u).get(i),d);
}
return result;
}
}

  

code for problem2

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map; /**
* Created by mcl on 2017/9/27.
*/
public class DNADeletion { final static int MOD=1000000007; public int differentProteins(String[] DNASequence, String[] codonTable) {
StringBuilder sb=new StringBuilder();
for(int i=0;i<DNASequence.length;++i) {
sb.append(DNASequence[i]);
}
final String S=sb.toString();
final int n=S.length();
int[][] nxt=new int[n+1][4];
nxt[n][0]=nxt[n][1]=nxt[n][2]=nxt[n][3]=-1;
for(int i=n-1;i>=0;--i) {
for(int j=0;j<4;++j) {
nxt[i][j]=nxt[i+1][j];
}
nxt[i][getIndex(S.charAt(i))]=i;
}
List<List<String>> lists=init(codonTable);
final int m=lists.size();
int[][] g=new int[n][m];
for(int i=0;i<n;++i) {
for(int j=0;j<m;++j) {
g[i][j]=-1;
for(int k=0;k<lists.get(j).size();++k) {
String s=lists.get(j).get(k);
int cur=i;
for(int t=0;t<s.length();++t) {
final int id=getIndex(s.charAt(t));
if(nxt[cur][id]==-1) {
cur=-1;
break;
}
cur=nxt[cur][id]+1;
}
if(cur!=-1&&(g[i][j]==-1||g[i][j]>cur)) {
g[i][j]=cur;
}
}
}
}
int[][] dp=new int[n+1][m];
for(int i=0;i<m;++i) {
if(g[0][i]!=-1) {
dp[g[0][i]][i]=1;
}
}
for(int i=0;i<n;++i) {
for(int j=0;j<m;++j) {
if(dp[i][j]==0) {
continue;
}
for(int k=0;k<m;++k) {
if(g[i][k]!=-1) {
dp[g[i][k]][k]=(dp[g[i][k]][k]+dp[i][j])%MOD;
}
}
}
}
int result=0;
for(int i=0;i<=n;++i) {
for(int j=0;j<m;++j) {
result=(result+dp[i][j])%MOD;
}
}
return result;
} List<List<String>> init(String[] codonTable) {
Map<String,Integer> map=new HashMap<>();
int id=0;
List<List<String>> lists=new ArrayList<>();
for(int i=0;i<codonTable.length;++i) {
String s=codonTable[i];
String key=s.substring(0,3);
String value=s.substring(4);
if(!map.containsKey(value)) {
map.put(value,id++);
lists.add(new ArrayList<>());
}
lists.get(map.get(value)).add(key);
}
return lists;
} int getIndex(char c) {
if(c=='A') {
return 0;
}
else if(c=='C') {
return 1;
}
else if(c=='T') {
return 2;
}
return 3;
}
}

  

code for problem3

import java.util.*;
import java.math.*;
import static java.lang.Math.*; public class CompanyRestructuring { public int fewestDivisions(String[] hasManaged) {
final int n=hasManaged.length;
boolean[][] g=new boolean[n][n];
for(int i=0;i<n;++i) {
for(int j=0;j<n;++j) {
if(hasManaged[i].charAt(j)=='Y') {
g[i][j]=true;
}
}
}
for(int k=0;k<n;++k) {
for(int i=0;i<n;++i) {
for(int j=0;j<n;++j) {
if(g[i][k]&&g[k][j]) {
g[i][j]=true;
}
}
}
}
boolean[] visited=new boolean[n];
int result=0;
for(int i=0;i<n;++i) {
if(visited[i]) {
continue;
}
List<Integer> left=new ArrayList<>();
List<Integer> right=new ArrayList<>();
for(int j=0;j<n;++j) {
if(i==j||g[i][j]&&g[j][i]) {
left.add(j);
visited[j]=true;
}
else {
right.add(j);
}
}
if(right.size()==0) {
result+=left.size();
continue;
}
final int lNum=left.size();
final int rNum=right.size();
boolean[][] graph=new boolean[lNum][rNum];
for(int ll=0;ll<lNum;++ll) {
for(int rr=0;rr<rNum;++rr) {
if(hasManaged[right.get(rr)].charAt(left.get(ll))=='Y') {
graph[ll][rr]=true;
}
}
}
result+=lNum-maxMatch(graph);
}
return result;
} int maxMatch(boolean[][] g) {
final int n=g.length;
final int m=g[0].length;
int[] match=new int[m];
Arrays.fill(match,-1);
int result=0;
for(int i=0;i<n;++i) {
if(find(i,m,g,new boolean[m],match)) {
++result;
}
}
return result;
}
boolean find(int u,int m,boolean[][] g,boolean[] visited,int[] match) {
for(int i=0;i<m;++i) {
if(!visited[i]&&g[u][i]) {
visited[i]=true;
int t=match[i];
match[i]=u;
if(t==-1||find(t,m,g,visited,match)) {
return true;
}
match[i]=t;
}
}
return false;
}
}

  

topcoder srm 435 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. 原型链(_proto_) 与原型(prototype) 有啥关系?

    prototype对象里面方法及属性是共享的...... 1.JavaScript 中每一个对象都拥有原型链(__proto__)指向其构造函数的原型( prototype),object._prot ...

  2. Django配置xadmin后台模板之坑(一)

    环境: Python3.6 + Django2.0 + xadmin2.0 一.安装 1.首先安装就会有一个坑,很多教程的安装是直接在虚拟环境下使用 pip install xadmin 或者 pip ...

  3. jQuery-设计模式

    [目录] 一.选择网页元素 二.改变结果集 三.链式操作 四.元素的操作:取值和赋值 五.元素的操作:移动 六.元素的操作:复制.删除和创建 七.工具方法 八.事件操作 九.特殊效果 [正文] 一.选 ...

  4. EL语言表达式 (二)【EL对数据的访问】

    一.访问方式: EL中访问数据和Java中访问数组的方式相同,即可以通过“[]”和“.”运算符进行访问.而且两种形式是等价的.如: 访问JavaBean对象userInfo中的id属性,可以写成下面两 ...

  5. SQL中的关联更新和关联删除

    在SQL中,经常用到关联查询,比如select a.* from A a inner join B b on a.PId=b.FId where 条件,SQL中也支持类似的关联更新和关联删除. 关联更 ...

  6. 20155228 2016-2017-2 《Java程序设计》第10周学习总结

    20155228 2016-2017-2 <Java程序设计>第10周学习总结 教材学习内容总结 网络 网络是能够波此通信的计算机的集合根据范}到的宽度,网络可以分为局域网和广域网.LAN ...

  7. 压缩和解压缩(I)

    ZipArchive 压缩方法 -(void)zipArchiveWithFiles { //创建解压缩对象 ZipArchive *zip = [[ZipArchive alloc]init]; / ...

  8. 【转】Apache Kylin 2.0为大数据带来交互式的BI

    本文转载自:[技术帖]Apache Kylin 2.0为大数据带来交互式的BI 编者注:Kyligence的联合创始人兼CEO Luke Han在上做题为“”的演讲. 基于Hadoop的SQL一直在被 ...

  9. C语言学习感受

    C语言,是我学习的第一种计算机语言,是他作为我编写程序的开始,在学习的时候,先学习了最基础的知识,在语言的理论学习语法上,我逐渐的了解了C语言并且对他有了基础的认识与理解,随着学习内容的不断深入,我逐 ...

  10. flask 对URL进行安全验证

    对URL进行安全验证 虽然我们已经实现了重定向会上一个页面的功能,但是安全问题不容忽视,鉴于referer和next容易被串篡改的特性,我们需要对这些值进行验证,否则会形成开放重定向漏洞   以URL ...