当前位置: 首页 > news >正文

网站建设制作设计开发福建网站开发文档撰写

网站建设制作设计开发福建,网站开发文档撰写,深圳网页制作费用,专业做效果图网站传送门 文章目录题意#xff1a;思路#xff1a;题意#xff1a; 思路#xff1a; 好久没写淀粉质了#xff0c;心血来潮复习一下。 淀粉质通常用来统计路径个数#xff0c;将路径分为子树内的和子树之间的。子树内的递归处理#xff0c;子树间的存下信息来每次都处理即…传送门 文章目录题意思路题意 思路 好久没写淀粉质了心血来潮复习一下。 淀粉质通常用来统计路径个数将路径分为子树内的和子树之间的。子树内的递归处理子树间的存下信息来每次都处理即可注意不要漏掉子树到根节点的贡献。 这个题要求不超过kkk的路径有多少条我们一个很容易想到的思路就是将每个子树到伪重心的距离都存下来每次与前面存下来的子树信息算一下答案。 这个实现起来复杂度很高每次计算答案需要遍历之前的子树这样就每一层的复杂度是O(n2)O(n^2)O(n2)级别的了显然不能接受。当然你可以使用一些黑科技维护一下但是没必要我们有更好的算法。 考虑一个容斥如果将所有路径都存下来排个序之后二分找答案这样算出来的答案可以发现不仅有两个子树之间的还有子树内部的所以我们在每次遍历完一个子树的时候将答案减去即可。 由于每一层需要排序复杂度O(nlognlogn)O(nlognlogn)O(nlognlogn)。 // Problem: 树 // Contest: AcWing // URL: https://www.acwing.com/problem/content/254/ // Memory Limit: 10 MB // Time Limit: 3000 ms // // Powered by CP Editor (https://cpeditor.org)//#pragma GCC optimize(Ofast,no-stack-protector,unroll-loops,fast-math) //#pragma GCC target(sse,sse2,sse3,ssse3,sse4.1,sse4.2,avx,avx2,popcnt,tunenative) //#pragma GCC optimize(2) #includecstdio #includeiostream #includestring #includecstring #includemap #includecmath #includecctype #includevector #includeset #includequeue #includealgorithm #includesstream #includectime #includecstdlib #includerandom #includecassert #define X first #define Y second #define L (u1) #define R (u1|1) #define pb push_back #define mk make_pair #define Mid ((tr[u].ltr[u].r)1) #define Len(u) (tr[u].r-tr[u].l1) #define random(a,b) ((a)rand()%((b)-(a)1)) #define db puts(---) using namespace std;//void rd_cre() { freopen(d://dp//data.txt,w,stdout); srand(time(NULL)); } //void rd_ac() { freopen(d://dp//data.txt,r,stdin); freopen(d://dp//AC.txt,w,stdout); } //void rd_wa() { freopen(d://dp//data.txt,r,stdin); freopen(d://dp//WA.txt,w,stdout); }typedef long long LL; typedef unsigned long long ULL; typedef pairint,int PII;const int N10010,mod1e97,INF0x3f3f3f3f; const double eps1e-6;int n,k; vectorPIIv[N]; vectorintq,qt; bool st[N];int get_size(int u,int f) {if(st[u]) return 0;int ans1;for(auto x:v[u]) if(x.X!f) {ansget_size(x.X,u);}return ans; }int get_wc(int u,int f,int tot,int wc) {if(st[u]) return 0;int sum1,mx0;for(auto x:v[u]) {if(x.Xf) continue;int nowget_wc(x.X,u,tot,wc);mxmax(mx,now); sumnow;}mxmax(mx,tot-sum);if(mxtot/2) wcu;return sum; }void get_dis(int u,int f,int w) {if(st[u]) return;q.pb(w);for(auto x:v[u]) {if(x.Xf) continue;get_dis(x.X,u,wx.Y);} }LL calc(int u) {if(st[u]) return 0;get_wc(u,-1,get_size(u,-1),u);LL ans0; st[u]true;for(auto x:v[u]) {get_dis(x.X,-1,x.Y);sort(q.begin(),q.end());for(int i0;iq.size();i) {int posupper_bound(q.begin(),q.end(),k-q[i])-q.begin();ans-min(pos,i1);qt.pb(q[i]); ansq[i]k;}q.clear();}sort(qt.begin(),qt.end());for(int i0;iqt.size();i) {int posupper_bound(qt.begin(),qt.end(),k-qt[i])-qt.begin(); ansmin(pos,i1);}qt.clear();for(auto x:v[u]) anscalc(x.X);return ans; }int main() { // ios::sync_with_stdio(false); // cin.tie(0);while(scanf(%d%d,n,k)(nk)) {for(int i1;in-1;i) {int a,b,w; scanf(%d%d%d,a,b,w);v[a].pb({b,w}); v[b].pb({a,w});} printf(%lld\n,calc(0));for(int i0;in;i) v[i].clear(),st[i]0;}return 0; } /**/
http://www.zqtcl.cn/news/280410/

相关文章:

  • 如何做英文系统下载网站快速排名工具免费
  • 苏州建网站必去苏州聚尚网络网页视频提取在线工具
  • 网站建设服务市场分析百度集团
  • 网站怎么企业备案信息做网站业务员如何跟客户沟通
  • 如何网站推广知名的集团门户网站建设费用
  • 网站入口设计规范专门做喷涂设备的网站
  • 最简单网站开发软件有哪些企业管理培训课程培训机构
  • 桂城网站制作公司wordpress 导航网站
  • 一个公司做网站需要注意什么条件网站备案 登陆
  • 百度网站介绍显示图片装修公司一般多少钱一平方
  • 网站销售如何做业绩我找伟宏篷布我做的事ko家的网站
  • 建立网站有哪些步骤?jsp网站开发详细教程
  • 网站怎么做直播功能旅游做攻略用什么网站
  • 企业外贸营销型网站如何写好软文推广
  • 免费建站的网址个人网站建设程序设计
  • 淘宝网站建设违规吗上海大公司
  • 大淘客怎么自己做网站自己开网站能赚钱吗
  • 大型门户网站开发北京网站建设管庄
  • 大连建设工程网站网站建设组织管理怎么写
  • wordpress英文站注册域名需要注意什么
  • 营销型网站的建设重点是什么深圳logo设计公司排名
  • 做网站的用什么软件呢网站排名优化服务公司
  • 网站开发完整视频网站集约化建设较好的城市
  • 网站建设和平面设计应用网站如何做
  • 自己做网站需要多少费用asa8.4 做网站映射
  • 商业网站 模板黑龙江省建设厅安全员考试
  • 网站新备案不能访问室内装修网站模板
  • 工程师报考网站wordpress设置视频图片不显示图片
  • 徐州网站建设公司排名成都住建平台
  • 用来备案企业网站国外免费外贸网站