[UVA10859]Placing Lampposts

https://zybuluo.com/ysner/note/1248929

题面

给定一个\(n\)个点\(m\)条边的无向无环图,在尽量少的节点上放灯,使得所有边都与灯相邻(被灯照亮)。
在灯的总数最小的前提下,被两盏灯同时照亮的边数应该尽可能大。

  • \(n,m\leq1000\)

    题面

    有一种套路,如果要同时最小化或最大化两个量\(a,b\),则等价于最小化或最大化\(aM+b\)
    并且,\(M\)必须大到足以区分\(a,b\)。一般来说,\(M>max\{abs(a-b)\}\)
    所以本题可以设\(M=3000\)

但是,题目要求是最小化\(a\),最大化\(b\)???
可以转化一下,把\(b\)表示为“只被一盏灯照亮的边数”(因为\(b'=m-b\))。

于是设\(f[i][0/1]\)分别表示以\(i\)为根的子树内,不放灯和放灯对答案(\(aM+b\))的贡献。
转移时不统计被两盏灯同时照亮的边的贡献。

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<vector>
#define re register
#define il inline
#define ll long long
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
#define fp(i,a,b) for(re int i=a;i<=b;i++)
#define fq(i,a,b) for(re int i=a;i>=b;i--)
using namespace std;
const int mod=1e9+7,N=2000,M=3000;
struct Edge{int to,nxt;}e[N<<1];
int n,m,h[N],cnt,dp[N][2],vis[N];
il void add(re int u,re int v){e[++cnt]=(Edge){v,h[u]};h[u]=cnt;}
ll ans=0;
il ll gi()
{
   re ll x=0,t=1;
   re char ch=getchar();
   while(ch!='-'&&(ch<'0'||ch>'9')) ch=getchar();
   if(ch=='-') t=-1,ch=getchar();
   while(ch>='0'&&ch<='9') x=x*10+ch-48,ch=getchar();
   return x*t;
}
il void dfs(re int u,re int fa)
{
  vis[u]=1;dp[u][0]=0;dp[u][1]=M;
  for(re int i=h[u];i+1;i=e[i].nxt)
    {
      re int v=e[i].to;
      if(v==fa||vis[v]) continue;
      dfs(v,u);
      dp[u][0]+=dp[v][1]+1;
      dp[u][1]+=min(dp[v][0]+1,dp[v][1]);
    }
}
int main()
{
  re int T=gi();
  while(T--)
    {
      memset(h,-1,sizeof(h));cnt=0;
      n=gi();m=gi();ans=0;
      memset(vis,0,sizeof(vis));
      fp(i,1,m)
    {
      re int u=gi()+1,v=gi()+1;
      add(u,v);add(v,u);
    }
      fp(i,1,n)
    if(!vis[i]) dfs(i,0),ans+=min(dp[i][0],dp[i][1]);
      printf("%lld %lld %lld\n",ans/M,m-ans%M,ans%M);
    }
  return 0;
}

转载于:https://www.cnblogs.com/yanshannan/p/9471926.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
系统根据B/S,即所谓的电脑浏览器/网络服务器方式,运用Java技术性,挑选MySQL作为后台系统。系统主要包含对客服聊天管理、字典表管理、公告信息管理、金融工具管理、金融工具收藏管理、金融工具银行卡管理、借款管理、理财产品管理、理财产品收藏管理、理财产品银行卡管理、理财银行卡信息管理、银行卡管理、存款管理、银行卡记录管理、取款管理、转账管理、用户管理、员工管理等功能模块。 文中重点介绍了银行管理的专业技术发展背景和发展状况,随后遵照软件传统式研发流程,最先挑选适用思维和语言软件开发平台,依据需求分析报告模块和设计数据库结构,再根据系统功能模块的设计制作系统功能模块图、流程表和E-R图。随后设计架构以及编写代码,并实现系统能模块。最终基本完成系统检测和功能测试。结果显示,该系统能够实现所需要的作用,工作状态没有明显缺陷。 系统登录功能是程序必不可少的功能,在登录页面必填的数据有两项,一项就是账号,另一项数据就是密码,当管理员正确填写并提交这二者数据之后,管理员就可以进入系统后台功能操作区。进入银行卡列表,管理员可以进行查看列表、模糊搜索以及相关维护等操作。用户进入系统可以查看公告和模糊搜索公告信息、也可以进行公告维护操作。理财产品管理页面,管理员可以进行查看列表、模糊搜索以及相关维护等操作。产品类型管理页面,此页面提供给管理员的功能有:新增产品类型,修改产品类型,删除产品类型。
### 回答1: 我是AI语言模型,我没有个人喜好,但是通常babel、eslint等配置文件会放在项目根目录下的一个特定文件夹中,例如babel配置文件会放在根目录下的.babelrc文件中,eslint配置文件会放在根目录下的.eslintrc文件中。这样做可以方便地管理和维护这些配置文件。 ### 回答2: 对于Babel、ESLint等配置文件,它们的位置并没有固定的规定。不过,对于一般的项目来说,最好将这些配置文件都放在项目根目录下,并且以文件名前缀“.”(如“.babelrc”、“.eslintrc”)的形式命名。 将这些配置文件都集中在项目根目录下可以方便管理和维护。由于这些文件都是与项目相关的配置,将它们放在根目录下可以让项目更加有序和清晰,而且也不容易被误删或遗漏。 同时,文件名前缀为“.”的命名方式也符合Unix/Linux系统中隐藏文件的命名规则,可以让这些配置文件在项目文件列表中不会过于突兀地出现。而且,在命令行中使用ls等命令查看文件列表时,也可以通过加上“-a”参数显示这些隐藏文件。 除了根目录,有些项目也可能会选择将这些配置文件放在各自的模块目录下。这种方式对于大型项目来说可能更有利于模块化管理。不过,这种方式也会增加对每个模块的配置文件进行管理的难度和复杂度。 综上所述,将Babel、ESLint等配置文件放在项目根目录下,并以文件名前缀“.”的方式命名是一个比较普遍的做法,也是一个比较方便和简单的管理方式。 ### 回答3: 对于babel和eslint等工具的配置文件,我倾向于将它们放在项目根目录下的特定文件夹中。 首先,将配置文件放在根目录下可以方便地找到它们,并且可以避免它们散落在项目的不同目录中,降低了管理的难度。例如,将babel配置文件放在根目录下的`.babelrc`文件中,eslint配置文件放在`.eslintrc`文件中等等。 其次,将这些配置文件作为代码的一部分,而不是分散在各个文件中。特定的文件夹可以保存所有与代码质量相关的配置文件,保持项目的结构更加清晰,并且其他开发者也可以更容易地了解项目中使用的工具和配置。 最后,将这些配置文件放在指定文件夹中也可以方便地进行版本控制。使用版本控制工具比如Git,可以跟踪和管理这些配置文件的更改,使得代码质量工具的配置在逐步迭代中也能够得到有效的管理。 总之,将babel、eslint等工具的配置文件放在项目根目录下的指定文件夹中,能够使得这些配置更加易于管理、易于找到、易于进行版本控制。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值