1499 图

原创 2017年10月04日 09:56:26

1499 图

Description

给一个无向图,你要将这些点分成A、B两个集合,使得满足A的导出子图是一个完全图,而B的导出子图是一个没有边的图。

但是事实上你不一定能够做到,所以你允许有错误。我们定义一个完美值为:

1.如果A中两点有边相连,则增加|i-j|的完美值。
2.如果B中两点无边相连,则增加|i-j|的完美值。
(i,j是这两个点的编号)

那么,我们让完美值最大就可以了。

N <= 1000, M <= 200000

Input

N, M 表示点数和边数

M行,

u,v表示一条无向边。

(不会有重边和自环)

Output

一个数,表示最大的完美值。

Input 示例

5 5
1 2
1 3
1 4
1 5
2 3

Output 示例

11

Solution

一道最小割的题目,但下面这种神奇的方法竟然过了。。。(虽然后期重测WA了一个,要看正解请跳过下一段代码)

#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
int n,m,ans,map[1005][1005];
int Abs(int x){
    if (x<0) return -x;
    return x;
}
int read(){
    int ans=0;
    char ch=getchar();
    while (ch<'0' || ch>'9') ch=getchar();
    while (ch>='0' && ch<='9'){
        ans=ans*10+ch-'0';
        ch=getchar();
    }
    return ans;
}
int main(){
    scanf("%d%d",&n,&m);
    for (int i=1;i<=m;i++){
        int x=read(),y=read();
        ans+=Abs(x-y);
        map[x][y]=map[y][x]=1;
    }
    int x=0;
    for (int i=1;i<=n;i++)
        for (int j=i+1;j<=n;j++)
            x+=j-i;
    ans=max(ans,x-ans);
    printf("%d\n",ans);
}
/*这段是正解(妥妥的最小割)*/
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#define N 5000005
#define INF 0x3f3f3f3f
using namespace std;
int st,ed,head[N],next[N],dis[N],son[N],q[N],/*p[200000],*/h[N],cnt;
bool vis[N];
int n,m,f[1010][1010],s[1010],t[1010];
int Abs(int x){
    if (x<0) return -x;
    return x;
}
void addedge(int u,int v,int l){
    next[++cnt]=head[u];son[cnt]=v;dis[cnt]=l;head[u]=cnt;
    next[++cnt]=head[v];son[cnt]=u;dis[cnt]=0;head[v]=cnt;
    //p[cnt-1]=cnt;p[cnt]=cnt-1;
}
bool bfs(){
    memset(h,0,sizeof(h));
    memset(vis,false,sizeof(vis));
    int hd=0,tl=1;q[1]=st;vis[st]=true;
    while (hd<tl){
        int u=q[++hd];
        int k=head[u];
        while (k!=0){
            int v=son[k];
            if ((not vis[v])&&(dis[k]>0)){
                q[++tl]=v;
                h[v]=h[u]+1;
                vis[v]=true;
            }
            k=next[k];
        }
    }
    if (h[ed]==0) return false; else return true;
}
int dfs(int u,int lim){
    if (u==ed) return lim;
    int k=head[u],l=0;
    while (k!=0){
        int v=son[k];
        if (h[v]==h[u]+1){
            int d=dfs(v,min(lim-l,dis[k]));
            dis[k]-=d;
            dis[k^1]+=d;
            l+=d;
            if (l==lim) break;
        }
        k=next[k];
    }
    return l;
}
int dinic(){
    int ans=0;
    while (bfs()){
        ans+=dfs(st,INF);
    }
    return ans;
}
int main(){
    scanf("%d%d",&n,&m);
    cnt=1;
    for (int i=1;i<=m;i++){
        int u,v;
        scanf("%d%d",&u,&v);
        f[u][v]=f[v][u]=1;
    }
    for (int i=1;i<=n;i++)
        for (int j=i+1;j<=n;j++)
            if (!f[i][j]){
                t[i]+=Abs(i-j);t[j]+=Abs(i-j);
                addedge(i,j,Abs(i-j));
                addedge(j,i,Abs(i-j));
            }
            else{
                s[i]+=Abs(i-j);s[j]+=Abs(i-j);
                addedge(i,j,Abs(i-j));
                addedge(j,i,Abs(i-j));
            }
    st=0;ed=n+1;
    int delta=0;
    for (int i=1;i<=n;i++){
        addedge(st,i,s[i]);
        addedge(i,ed,t[i]);
    }
    int ans=dinic();
    for (int i=1;i<=n;i++)
        for (int j=i+1;j<=n;j++)
            delta+=Abs(i-j);
    printf("%d\n",delta-ans/2);
    return 0;
}

九度OJ 1499 项目安排 -- 动态规划

题目地址:http://ac.jobdu.com/problem.php?pid=1499 题目描述: 小明每天都在开源社区上做项目,假设每天他都有很多项目可以选,其中每个项目都有一...
  • JDPlus
  • JDPlus
  • 2014年03月05日 15:14
  • 1557

BZOJ 1499 NOI2005 瑰丽华尔兹 单调队列

题目大意:给定一个m*n的地图,一些点有障碍物,钢琴初始在一个点,每个时间段可以选择向给定的方向移动一段距离,求最长路径长 朴素DP的话,我们有T个时间段,每个时间段有m*n个点,n个时间,一定会超...
  • PoPoQQQ
  • PoPoQQQ
  • 2014年10月14日 10:43
  • 1688

九度笔记之 1499:项目安排 的两种动态规划方法比较

为何在有时间限制的项目规划问题中,动态规划的更新变量用项目而不是用时间更好。...
  • KingEasternSun
  • KingEasternSun
  • 2013年08月08日 14:00
  • 1277

[BZOJ 1499][NOI 2005]瑰丽华尔兹(DP+单调队列优化)

题目链接http://www.lydsy.com/JudgeOnline/problem.php?id=1499思路一个很显然的O(nmT)O(nmT)的做法就是令f[t][i][j]f[t][i][...
  • qpswwww
  • qpswwww
  • 2015年04月25日 11:11
  • 934

【Tsinsen】A1499. Theresa与数据结构 cdq分治套树状数组套平衡树

传送门:【Tsinsen】A1499. Theresa与数据结构 题目分析:三维平面的统计问题,用cdq分治套cdq分治套树状数组会超时= =。。。最后写了一个cdq套树状数组套treap过的。。...
  • u013368721
  • u013368721
  • 2014年12月01日 22:25
  • 842

10款超值价笔记本易PC爆1499

  • 2009年06月05日 22:14
  • 173KB
  • 下载

Bzoj - 1499 [Noi2005] 瑰丽华尔兹 [DP][单调队列优化]

1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec  Memory Limit: 64 MB Submit: 1715  Solved: 1043 [Submit][Stat...
  • PomeCat
  • PomeCat
  • 2017年10月11日 09:51
  • 89

1499: [NOI2005]瑰丽华尔兹

1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec  Memory Limit: 64 MB Submit: 1359  Solved: 814 [Submit][St...
  • CRZbulabula
  • CRZbulabula
  • 2016年08月12日 20:36
  • 198

ZOJ1499经典dp

参考别人解题报告写得,很经典,开始很容易想到dp,dp[i]记录已i结尾满足递增,并且结尾值最小的长度。 但是如果最后的值相同还需要使得前面的值尽可能大,#include #include char...
  • nash142857
  • nash142857
  • 2012年08月29日 13:51
  • 847

bzoj 1499: [NOI2005]瑰丽华尔兹

Description 你跳过华尔兹吗?当音乐响起,当你随着旋律滑动舞步,是不是有一种漫步仙境的惬意?众所周知,跳华尔兹时,最重要的是有好的音乐。但是很少有几个人知道,世界上最伟大的钢琴家一生都...
  • lqybzx
  • lqybzx
  • 2016年10月28日 16:02
  • 354
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:1499 图
举报原因:
原因补充:

(最多只允许输入30个字)