转载请注明出处,谢谢

viewmode=contents">http://blog.csdn.net/ACM_cxlove?viewmode=contents    by---cxlove

水水更健康,最终回到1800+了。。。

DIV2 1000pt

显然每一列是独立的。分开考虑。

对于某一列。假设按单个字符U , D从下往上考虑的话。发现连续两个U的话。以下的U能够移动的位置受上面一个影响。

只是因此能够想到相邻的U , D互相限制位置,能够依次处理。相邻同样字符的话。 能够作为一个字符。

做法:把相邻的U合并,相邻的D合并。dp[i][j]表示前i个部分处理完。第i个部分最靠上的一个位置为j。

这种话,假设当前为U。那么向上移动的最远位置为下一个部分最靠下的D的位置。

假设当前为D。那么向下移动的最远位置便是上一个部分最靠上的U的位置。

这样就能够搞出每个部分的上下界,然后分别DP。

typedef long long LL;
const LL MOD = 1000000007;
const int N = 55;
LL dp[N][N];
void add (LL &a , LL b) {
a += b;
a = (a % MOD + MOD) % MOD;
}
LL mut (LL a , LL b) {
a = a * b % MOD;
a = (a + MOD) % MOD;
return a;
}
LL gao_up (vector<int>&v , int limit) {
int n = v.size();
LL c[N][N]; memset (c , 0 , sizeof(c));
c[n - 1][limit - 1] = 1;
for (int i = n - 2 ; i >= 0 ; i --) {
for (int j = limit ; j >= 0 ; j --) {
if (c[i + 1][j] == 0) continue;
for (int k = v[i] ; k < j ; k ++) {
add (c[i][k] , c[i + 1][j]);
}
}
}
LL ans = 0;
for (int i = 1 ; i <= limit ; i ++) {
add (ans , c[0][i]);
}
return ans;
}
LL gao_down (vector<int>&v , int down , int up) {
int n = v.size();
LL c[N][N]; memset (c , 0 , sizeof(c));
c[0][down] = 1;
for (int i = 0 ; i < n ; i ++) {
for (int j = 0 ; j <= up ; j ++) {
if (c[i][j] == 0) continue;
for (int k = j + 1 ; k <= v[i] ; k ++)
add (c[i + 1][k] , c[i][j]);
}
}
return c[n][up];
}
vector<vector<int> > v;
class FoxAndShogi {
public:
int differentOutcomes(vector <string> board) {
int row = board.size() , col = board[0].size();
LL ans = 1LL;
for (int c = 0 ; c < col ; c ++) {
memset (dp , 0 , sizeof(dp));
string s = "";
v.clear ();
for (int r = row - 1 ; r >= 0 ; r --)
s = s + board[r][c];
int first = -1;
for (int i = 0 , pre = -1 ; i < s.size() ; i ++) {
if (s[i] == '.') continue;
if (s[i] == 'D' && pre == 0) {
v[v.size() - 1].push_back (i + 1);
}
else if (s[i] == 'U' && pre == 1) {
v[v.size() - 1].push_back (i + 1);
}
else {
if (first == -1) {
if (s[i] == 'U') first = 0;
else first = 1;
}
vector<int>t;
t.push_back(i + 1);
v.push_back(t);
if ( s[i] == 'U') pre = 1;
else pre = 0;
}
}
dp[0][0] = 1;
for (int i = 0 ; i < v.size() ; i ++) {
for (int j = 0 ; j <= row ; j ++) {
if (dp[i][j] == 0) continue;
// up
if ((first == 0 && i % 2 == 0) || (first == 1 && i % 2 == 1)){
int now = v[i][v[i].size() - 1];
int limit = (i + 1) < v.size() ? v[i + 1][0] : (col + 1);
for (int k = now ; k < limit ; k ++) {
add (dp[i + 1][k] , mut (dp[i][j] , gao_up (v[i] , k + 1)));
}
}
//down
else {
int now = v[i][v[i].size() - 1];
for (int k = j + 1 ; k <= now ; k ++) {
add (dp[i + 1][k] , mut (dp[i][j] , gao_down (v[i] , j , k)));
}
}
}
}
LL tmp = 0;
for (int i = 0 ; i <= row ; i ++)
add (tmp , dp[v.size()][i]);
// cout << tmp << endl;
ans = mut (ans , tmp);
}
return ans;
}
};

DIV1 250PT

把L,R所有提取出来,先推断下是否一致。

然后 比較下位置

DIV1 500 PT

异或结果 小于等于LIMIT,先处理相等的情况,既异或结果每一位都和LIMIT相等,列方程组,求一下秩。

否则的话。必定存在某一位,LIMIT中为1。实际为0,并且高位和LIMIT一致,低位随意 。

所以枚举相隔的这个位置。相同是列方程组求解。

typedef long long LL;
int a[100][100];
int n , m ;
long long gauss(){ int i,j,row=1,col;
for (col=1;col<=m;++col){
for (i=row;i<=n;++i)
if (a[i][col])
break ;
if (i>n)
continue ;
if (i!=row){
for (j=col;j<=m;++j)
swap(a[row][j],a[i][j]);
swap(a[i][m + 1],a[row][m + 1]);
}
for (i=row+1;i<=n;++i)
if (a[i][col]){
for (j=col;j<=m;++j)
a[i][j]^=a[row][j];
a[i][m + 1]^=a[row][m + 1];
}
++row;
}
for (i=row;i<=n;++i)
if (a[i][m + 1])
return 0;
return 1ll<<(long long)(m-row+1);
}
class XorCards {
public:
long long numberOfWays(vector<long long> number, long long limit) {
LL ans = 0;
m = number.size();n = 61;
memset (a , 0 , sizeof(a));
for (int i = 0 ; i < 61 ; i ++) {
for (int j = 0 ; j < m ; j ++) {
if (number[j] & (1LL << i)) a[i + 1][j + 1] = 1;
}
a[i + 1][m + 1] = (limit & (1LL << i)) ? 1 : 0;
}
ans = gauss ();
for (int i = 0 ; i < 61 ; i ++) {
if (!(limit & (1LL << i))) continue;
memset (a , 0 , sizeof(a));
for (int j = i + 1 ; j < 61 ; j ++) {
for (int k = 0 ; k < m ; k ++) {
if (number[k] & (1LL << j)) a[j + 1][k + 1] = 1;
}
a[j + 1][m + 1] = (limit & (1LL << j)) ? 1 : 0;
}
for (int k = 0 ; k < m ; k ++) {
if (number[k] & (1LL << i)) a[i + 1][k + 1] = 1;
}
ans += gauss ();
}
return ans;
}
};

DIV1 1000PT

排序方式价格优势,然后 镶上每次迭代暴力,folyd寻求最短的价格后,值。。

SRM 590 DIV1的更多相关文章

  1. topcoder srm 590 div1 (max_flow_template)

    problem1 link 对于每一个,找到其在目标串中的位置,判断能不能移动即可. problem2 link 如果最后的$limit$为$11=(1011)_{2}$,那么可以分别计算值为$(10 ...

  2. Topcoder SRM 643 Div1 250<peter_pan>

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

  3. Topcoder Srm 726 Div1 Hard

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

  4. 图论 SRM 674 Div1 VampireTree 250

    Problem Statement      You are a genealogist specializing in family trees of vampires. Vampire famil ...

  5. SRM 583 DIV1

    A 裸最短路. class TravelOnMars { public: int minTimes(vector <int>, int, int); }; vector<int> ...

  6. Topcoder SRM 602 div1题解

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

  7. 状态压缩DP SRM 667 Div1 OrderOfOperations 250

    Problem Statement      Cat Noku has just finished writing his first computer program. Noku's compute ...

  8. 数学 SRM 690 Div1 WolfCardGame 300

    Problem Statement      Wolf Sothe and Cat Snuke are playing a card game. The game is played with exa ...

  9. SRM 618 DIV1 500

    非常棒的组合问题,看了好一会,无想法.... 有很多做法,我发现不考虑顺序的最好理解,也最好写. 结果一定是两种形式 A....A   dp[n-1] A...A...A sgma(dp[j]*dp[ ...

随机推荐

  1. hdu4578(线段树)

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=4578 题意:n个数,初始值为0,4种操作: 1.将某个区间所有值加上另一个值: 2.将区间所有值都乘上 ...

  2. 单点更新线段树 RMQ

    D. Xenia and Bit Operations time limit per test 2 seconds memory limit per test 256 megabytes input ...

  3. Yii学习笔记之三(在windows 上安装 advanced )

    首先说一下下载地址: http://www.yiiframework.com/download/ 然后将下载下来的文件进行解压到 你指定的文件夹 解压过程中假设报什么错误 直接忽略掉 我的解压文件夹是 ...

  4. linux--文件夹下批量改动IP

    sed -i 's/10.11/10.22/g' `grep ir 10.11 *| grep -E'.xml:|.cfg:|.ini:|.wsdl|.properties:' |awk -F:'{p ...

  5. wampserver图标黄色

    wampserver图标黄色(多个httpd.exe服务,以前装了apache) 服务--->httpd.exe右击这个服务打开文件位置就知道是不是wampserver的服务.如果不是就停掉这给 ...

  6. Android HAL

  7. 数据库采用多表连接查询,对应javaBean文件连接方式

    在一个Web项目中,只要是存在数据库就一定会有JavaBean文件.一个JavaBean文件会对应一张数据库中的表,供dao中的代码来调用用来存取数据.我们都知道,在数据库设计的时候,如果A.B两张表 ...

  8. 安装ecshop提示“安装数据失败”或者“创建管理员帐号”

    解决方法: 在install/includes/init.php文件的顶部,<?php 下增加: date_default_timezone_set ('Asia/Shanghai'); 即可 ...

  9. windows phone 7 通过Post提交URL到服务器,从服务器获取数据(比如登陆时候使用)

    原文:windows phone 7 通过Post提交URL到服务器,从服务器获取数据(比如登陆时候使用) HttpWebRequest myRequest = (HttpWebRequest)Web ...

  10. java.lang.OutOfMemoryError: Java heap space错误和方法(集、转)

    错误的方式来解决溢出下面的堆空间是从网上找: java.lang.OutOfMemoryError: Java heap space ================================= ...