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

一般网站设计多少钱房产官方网站

一般网站设计多少钱,房产官方网站,网站建设完成以后应该怎样备份,蚌埠市建设管理局官方网站学习资料:代码随想录 108. 冗余连接 卡码网题目链接(ACM模式) 判断是否有环的依据为,利用并查集,isSame函数,判断当下这条边的两个节点入集前是否为同根,如果是的话,该边就是会构…

学习资料:代码随想录

108. 冗余连接

卡码网题目链接(ACM模式)

判断是否有环的依据为,利用并查集,isSame函数,判断当下这条边的两个节点入集前是否为同根,如果是的话,该边就是会构成环的那条边

#include <iostream>
#include <vector>
using namespace std;int n;
vector<int> father=vector<int>(1001,0);void init(){for(int i=0;i<n;i++){father[i]=i;}
}
int find(int u){return u==father[u]?u:father[u]=find(father[u]);
}bool isSame(int u,int v){u=find(u);v=find(v);return u==v;
}void join(int u,int v){u=find(u);v=find(v);if(u==v) return;father[v]=u;
}int main(){int s,t;cin>>n;init();for(int i=0;i<n;i++){cin>>s>>t;if(isSame(s,t)) {cout<<s<<' '<<t<<endl;return 0;}else{join(s,t);}}
}

109. 冗余连接II

卡码网题目链接(ACM模式)

分三种情况:代码随想录

对于有两个入度的节点的情况,需要先倒序记录节点入度情况,找到入度为2的那个节点对应的两条边,判断应该删除哪条边。判断方法为,先看第一条(之前是倒序遍历,即看最后这条),用isSame函数判段是否为构成环的这条边,如果是,cout这条,如果不是cout另一条;

如果没有入度为2的节点,即情况3,直接用isSame函数判断就可以了

#include <iostream>
#include <vector>
using namespace std;
int n;
vector<int> father=vector<int>(1001,0);
void init(){for(int i=1;i<=n;i++){father[i]=i;}
}int find(int u){return u==father[u]?u:father[u]=find(father[u]);
}bool isSame(int u,int v){u=find(u);v=find(v);return u==v;
}void join(int u,int v){u=find(u);v=find(v);if(u==v) return;father[v]=u;
}bool isTreeAfterDeleteEdge(const vector<vector<int>>& edges,int todelete){init();for(int i=0;i<n;i++){if(i==todelete){continue;}if(isSame(edges[i][0],edges[i][1])) return false;join(edges[i][0],edges[i][1]);}return true;
}void deletedEdge(const vector<vector<int>>& edges){init();for(int i=0;i<n;i++){if(isSame(edges[i][0],edges[i][1])){cout<<edges[i][0]<<' '<<edges[i][1];return;}join(edges[i][0],edges[i][1]);}
}int main(){cin>>n;vector<vector<int>> edges;vector<int> inDegree(n+1,0);int s,t;for(int i=0;i<n;i++){cin>>s>>t;edges.push_back({s,t});inDegree[t]++;}vector<int> doubleDegree;for(int i=n-1;i>=0;i--){if(inDegree[edges[i][1]]==2){doubleDegree.push_back(i);}}if(doubleDegree.size()>0){if(isTreeAfterDeleteEdge(edges,doubleDegree[0])){cout<<edges[doubleDegree[0]][0]<<' '<<edges[doubleDegree[0]][1];}else{cout<<edges[doubleDegree[1]][0]<<' '<<edges[doubleDegree[1]][1];}return 0;}deletedEdge(edges);}

有几个小点:

1、既然 isTreeAfterRemoveEdge()getRemoveEdge() 都是靠并查集判断是否成环,能不能只用 getRemoveEdge() 一个函数来处理所有情况?

不能!

getRemoveEdge() 只能处理「无入度为 2」的情况(即情况三)
如果你碰到的是「有一个点入度为 2」(即情况一、情况二),就必须要先判断删哪一条边,这一步 getRemoveEdge() 做不到。

2、对于find函数会改变并查集的结构,这并不改变每一个节点的根节点,所以虽然在join函数和isSame函数的使用中,find会使并查集结构改变,对判断没有影响

3、对于vector,赋值方法v[i] = x需要以前设置vector大小,赋值方法v.push_back(x)不需要提前设置vector大小

http://www.dtcms.com/wzjs/781291.html

相关文章:

  • 酷站欣赏wordpress图片压缩插件
  • iis更改默认网站庄河市城乡规划建设局网站
  • 嘉兴网站做动态图片的网站
  • 网站建设课程设计格式wordpress默认邮件文件
  • 网站建设方案应急处置深圳外贸电商网站建设
  • 网站空间送数据库成都设计公司提成
  • aspcms手机网站模板免费头像生成制作网站
  • 网站建设要懂哪些技术张雪峰谈建筑室内设计
  • 企业网站怎么做外链中装建设公司待遇好吗
  • 免费网站推广软件下载怎么做域名网站备案
  • 为什么做金融网站犯法赛罕区城乡建设局网站
  • 机械公司网站模板网站建设哪个比较好
  • 网站开发需求列表汕头百度关键词优化
  • 舟山市建设局网站游戏网站建设成功案例
  • 网站开发代淘宝店铺装修注册完域名怎么做网站
  • 官方网站开发哪家便宜企业网站设计行业
  • 网站编辑工作wordpress+音乐盒
  • 搭建免费网站湖北省建设厅官方网站文件
  • 怎样做淘宝推广网站请seo的人帮做网站排名
  • 一流的网站建设流程WordPress微信强制跳转插件
  • 做跨境都有哪些网站在线看网址不收费不登录
  • 网站备份信息推广引流平台
  • 合肥做公司网站公司谷歌广告联盟官网
  • 在网站建设会议上的讲话制作公司网站需要那些资料
  • 网站建设公司的市场开发方案Wordpress只做后端
  • 南沙网站建设价格网页制作价格
  • 网站优化注意事项从零搭建企业网站
  • 国际外贸网站推广外贸网站开发
  • 潍坊建设gc局网站深圳保障性住房查询
  • 网站开发后端待遇慈溪做网站