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. UVA 11168 Airport(凸包)

    Airport [题目链接]Airport [题目类型]凸包 &题解: 蓝书274页,要想到解析几何来降低复杂度,还用到点到直线的距离公式,之后向想到预处理x,y坐标之和,就可以O(1)查到距 ...

  2. 笔记 : CSS3实现背景渐变过渡

    使用CSS3的人都知道背景background-image是可以线性渐变(linear-gradient)和径向渐变(radial-gradient),但是想要做到过渡动画,单纯的background ...

  3. JavaScript-switch-case运用-案例

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  4. sqlserver字符集问题(中文出乱码,排序错误等)

    在创建sqlserver 数据库时未指定排序字符集,databases则会使用instances的排序规则.为了支持中文,需要设置成Chinese_PRC_CI_AS. (1)通过sql脚本修改 -- ...

  5. gispro试用版账户注册

    1.注册账户 http://www.esri.com/zh-cn/arcgis/products/arcgis-pro/trial 2.分配账户权限 3.gispro可以登录了

  6. 136. Single Number(位运算)

    Given a non-empty array of integers, every element appears twice except for one. Find that single on ...

  7. 检索系统向量化计算query-doc相似度

    def cal_sim2(A,B): ''' A :query [1,2] B: answers [[1,2],[3,5]] ''' need_norm=False A = np.array(A) B ...

  8. Discuz目录结构

    /source/class/task站点任务内置包 task_avatar.php头像类任务 task_blog.php发表日志任务 task_connect_bind.phpQQ 帐号绑定任务 ta ...

  9. Day8 面向对象

    一.面向对象和面向过程 各位,我们现在如果要将大象放冰箱,用面向过程怎么实现呢? 1.把大象放到冰箱里 第一步:把冰箱门打开 第二步:把大象放进去 第三步:把门关上 def open_fridge_d ...

  10. Vue系列之 => 动画

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...