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的更多相关文章

  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. pip install pyinstaller

    C:\Users\coder211\Desktop>pip install pyinstallerCollecting pyinstaller Downloading PyInstaller-3 ...

  2. Eclipse + Pydev问题 : pydev unresolved import

    http://blog.csdn.net/qq_22765745/article/details/71054030http://blog.csdn.net/amghost/article/detail ...

  3. html5 手机端 通讯录 touch 效果

    不说那么多直接上代码. <html> <head> <meta http-equiv="Content-Type" content="tex ...

  4. vs2015 C#打包程序为exe

    说明:将自己写的C#源代码打包后生成exe,直接安装在别人的电脑上运行,就像我们在网上下载别人的软件一样,很高大上,vs2015提供了打包和生成exe功能: 步骤一.打开vs2015(其他版本应该也是 ...

  5. HDU 1014 Uniform Generator(题解)

    Uniform Generator Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others ...

  6. Sitecore CMS中查看标准字段

    什么是标准字段? 标准字段是字段及其字段组的集合,用于包含有关Sitecore中项目的可配置元数据.Sitecore中继承自“标准模板”模板的任何项目都将包含这些字段. 可以在“标准模板”模板项找到/ ...

  7. uva 1632 Alibaba

    题意: 一个人要从如果干个地方拿货,每个地方的货物是有存在时间的,到了某个时间之后就会消失. 按照位置从左到右给出货物的位置以及生存时间,这个人选择一个最优的位置出发,问拿完货物的最少时间. 思路: ...

  8. ReactiveObjC

    简介: RAC 指的就是 RactiveCocoa ,是 Github 的一个开源框架,能够帮我们提供大量方便的事件处理方案,让我们更简单粗暴地去处理事件,现在分为 ReactiveObjC 和 Re ...

  9. Lua语言特色

    [1]多重赋值 多重赋值规则:若值的个数少于变量的个数,那么多余的变量会被赋值为nil 若值的个数多余变量的个数,那么多余的值会被“悄悄地”丢弃掉. 多重赋值应用示例: a, b = , * prin ...

  10. 【Alpha版本】冲刺阶段——Day6

    [Alpha版本]冲刺阶段--Day6 阅读目录 今日进展 问题困难 明日任务 今日贡献量 TODOlist [今日进展] 为注册模块增加界面代码 public static void Windows ...