topcoder srm 703 div1 -3
1、给出一个包含$n$个元素的数组$x$,构造出一个有向无环图满足从节点$i$出发可以访问到的节点数为$x_{i}$。
思路:按照$x$从小到大排序。然后从前向后处理,当前节点依次与前面已经处理的节点连边。
#include <iostream>
#include <map>
#include <string>
#include <stdio.h>
#include <vector>
#include <set>
#include <algorithm>
#include <string.h>
#include <fstream>
#include <sstream>
using namespace std; const int N=555;
const int mod=998244353; int get(long long x)
{
int cnt=0;
for(int i=0;i<55;++i)
{
if(x&(1ll<<i)) ++cnt;
}
return cnt;
} class DAGConstruction
{
public:
vector <int> construct(vector <int> x)
{
const int n=(int)x.size();
long long f[55];
memset(f,0,sizeof(f));
vector<int> ans,V;
vector<pair<int,int>> p;
for(int i=0;i<n;++i)
{
f[i]=1ll<<i;
p.push_back(make_pair(x[i],i));
}
sort(p.begin(),p.end());
for(int i=0;i<(int)p.size();++i)
{
int c=p[i].first;
int u=p[i].second;
for(int j=0;j<(int)V.size();++j)
{
int t=V[V.size()-1-j];
if(get(f[u]|f[t])<=c)
{
f[u]|=f[t];
ans.push_back(u);
ans.push_back(t);
}
}
V.push_back(u);
if(get(f[u])<c) return vector<int>(1,-1);
}
return ans;
}
};
2、在$x$ 轴上有$n$个点A,$x$轴上方有$n$个点B,A集合中的每个点在B集合中的每个点找到一个匹配点,B集合中每个点只能与A中的一个点匹配,使得$n$条线段任意两条线段不相交。问有多少种方法。
思路:将B集合按照$y$坐标排序。A集合按照$x$排序。每次枚举A中的一个点与B中最高的点连线,这样分成两段,继续进行这样的匹配。
#include <iostream>
#include <map>
#include <string>
#include <stdio.h>
#include <vector>
#include <set>
#include <algorithm>
#include <string.h>
#include <fstream>
#include <sstream>
using namespace std; const int N=555;
const int mod=1000000007; vector<int> D,X,Y;
int n; map<vector<int>,int> mp[55][55]; int dfs(int L,int R,vector<int> S)
{ if(S.size()<=1) return 1;
if(mp[L][R].count(S)) return mp[L][R][S]; long long ans=0;
for(int i=L;i<=R;++i)
{ const int x1=X[S.back()]-D[i];
const int y1=Y[S.back()];
vector<int> ls,rs;
int ok=1;
for(int j=0;j<(int)S.size()-1;++j)
{
const int x0=X[S[j]]-D[i];
const int y0=Y[S[j]];
const int sgn=x0*y1-x1*y0;
if(sgn==0)
{
ok=0;
break;
}
if(sgn<0) ls.push_back(S[j]);
else rs.push_back(S[j]);
}
if(ok&&ls.size()==i-L&&rs.size()==R-i) ans+=1ll*dfs(L,i-1,ls)*dfs(i+1,R,rs)%mod;
}
return mp[L][R][S]=ans%mod;
} class CoastGuard
{
public:
int count(vector <int> d, vector <int> x, vector <int> y)
{
n=(int)d.size();
D=d;
sort(D.begin(),D.end());
vector<pair<int,int>> p;
vector<int> S;
for(int i=0;i<n;++i)
{
p.push_back(make_pair(y[i],x[i]));
S.push_back(i);
}
sort(p.begin(),p.end());
for(int i=0;i<n;++i)
{
Y.push_back(p[i].first);
X.push_back(p[i].second);
}
return dfs(0,n-1,S);
}
};
topcoder srm 703 div1 -3的更多相关文章
- 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)其 ...
随机推荐
- install scala & spark env
安装Scala 1,到http://www.scala-lang.org/download/ 下载与Spark版本对应的Scala.Spark1.2对应于Scala2.10的版本.这里下载scala- ...
- [ English ] Ping sb.
What does "Ping Me" mean? Recently, when I asked a colleague to ping me, he responded wi ...
- Sitecore营销自动化
增加与战略性自动化营销系统的互动 Sitecore营销自动化基于DMS中的Sitecore个性化功能.营销自动化系统使用诸如位置,设备和先前访问或购买之类的客户数据来影响用户沿着购买路径的旅程.这些系 ...
- 多线程实现Thread.Start()与ThreadPool.QueueUserWorkItem两种方式对比
Thread.Start(),ThreadPool.QueueUserWorkItem都是在实现多线程并行编程时常用的方法.两种方式有何异同点,而又该如何取舍? 写一个Demo,分别用两种方式实现.观 ...
- [博客迁移]探索Windows Azure 监控和自动伸缩系列3 - 启用Azure监控扩展收集自定义监控数据
上一篇我们介绍了获取Azure的监控指标和监控数据: http://www.cnblogs.com/teld/p/5113376.html 本篇我们继续:监控虚拟机的自定义性能计数器. 随着我们应用规 ...
- GCD(III)
GCD 线程间的通信 在iOS开发过程中,我们一般在主线程里边进行UI刷新,例如:点击.滚动.拖拽等事件.我们通常把一些耗时的操作放在其他线程,比如说图片下载.文件上传等耗时操作.而当我们有时候在其他 ...
- 用 hashcat 破解 WIFI WPA2破解
首先用CDlinux系统进行抓包,CDlinux抓包我就不详细说明 到这里可以查看如何安装CDlinux http://jingyan.baidu.com/article/7f766daf5173a9 ...
- ubuntu16.04——WingIDE安装 操作服务器是一件很好玩的事情
1.在服务器上部署环境时,区分linux 系统和winddos系统 2.下载安装包: 3.输入命令操作 4.进入相对应的目录下: 5.命令 6.发生错误,更新环境 7.安装成功
- HasThisTypePatternTriedToSneakInSomeGenericOrParameterizedTypePatternMatchingStuffAnywhereVisitor
看到的最长的类名: HasThisTypePatternTriedToSneakInSomeGenericOrParameterizedTypePatternMatchingStuffAnywhere ...
- Failed to start component [StandardEngine[Tomcat].StandardHost[localhost]]
1.问题场景描述:一个maven项目启动时候,偶尔会报tomcat的这个错误(如图:) 随机报错,有时频率很高,要一直重新启动很多次可能还是启动不了,有时不报错.. 2.解决过程:网上各种寻找解决办法 ...