当前位置: 首页 > 编程日记 > 正文

南大算法设计与分析课程OJ答案代码(5)--割点与桥和任务调度问题

问题 A: 割点与桥

时间限制: 1 Sec  内存限制: 5 MB
提交: 475  解决: 34
提交 状态 算法问答 

题目描述

给出一个无向连通图,找到所有的割点和桥

输入

第一行:点的个数,如果点个数是n,他们的编号为0 ~ n-1

余下的行:每行代表一条边,如“0 2”代表顶点0和顶点2有一条边 (一条边只出现一次,如出现“0 2”则不会出现“2 0”)


输出

这次需要大家先输出一个字符串,它是“我已阅读关于抄袭的说明”的汉语拼音.输出此行的提交我们将认为已经完全阅读并了解了“关于抄袭的说明”公告.

所有的割点和所有的桥,先输出割点再输出桥

割点按编号升序排列,桥按边的升序排列,如“0 2”小于“0 3”,“1 5”小于“2 3”(边的输出和排列总是把小顶点放前面,所以输出总是“0 2”而非“2 0”)

样例输入

5
1 2
1 3
2 4
0 1
0 2

样例输出

wo yi yue du guan yu chao xi de shuo ming
1
2
1 3
2 4

提示

两个算法的伪代码书上都有了,就不多说了。

这个题比较坑的地方是空间复杂度,开始保存图一直使用的set<int>,一直不过,改成vector<int>就过了

本题中,为了节省空间,我尽量使用了new,在染色节点的时候,我直接使用了discovertime来表示,当discovertime==0时表示节点未访问,discovertime<0表示正在访问,discovertime>0时表示访问结束。所以在DFS刚访问节点设置discovertime时,我将discovertime设置为-time,结束时去绝对值。

答案

#include <iostream>
#include <map>
#include <set>
#include <vector>
#include <algorithm>
using namespace std;//找割点
void DFS_find_cutvertex(vector<int>* g, int point, int time, pair<int, int>* times,vector<int> & result,int& treenum,int parent) {++time;//在访问节点是,将back设为当前时间times[point].second = time * -1;times[point].first = time;//节点染成灰色for (auto i = g[point].begin(); i!= g[point].end(); i++) {//到此时,此时i表示需要遍历的下一个邻居节点int y = *i;if (times[*i].second == 0) {if (point == 0) treenum++;DFS_find_cutvertex(g, *i, time, times,result,treenum,point);//判断是否为割点if (times[*i].first >= abs(times[point].second) && point != 0)result.emplace_back(point);times[point].first = min(times[point].first, times[*i].first);}else {//正在被访问,这能代表BF的边?if (times[*i].second < 0 && *i != parent) {times[point].first = min(times[point].first, abs(times[*i].second));}}}//节点染成黑色times[point].second = abs(times[point].second);
}//找桥,对寻找割点的程序简单修改
void DFS_find_bridge(vector<int>* g, int point, int time, pair<int, int>* times, vector<pair<int,int>> & result,int parent) {++time;//当discovertime为负数时,表示正在被访问times[point].second = time * -1;times[point].first = time;for (auto i = g[point].begin(); i != g[point].end(); i++) {if (times[*i].second == 0) {DFS_find_bridge(g, *i, time, times, result,point);times[point].first = min(times[point].first, times[*i].first);if (times[*i].first > abs(times[point].second)) {//保持结果中的边小的点在前if(point < *i) result.emplace_back(pair<int, int>(point, *i));else result.emplace_back(pair<int, int>(*i,point));}}else {if (times[*i].second < 0 && *i != parent) {times[point].first = min(times[point].first, abs(times[*i].second));}}}//节点染成黑色times[point].second =abs(times[point].second);
}int main()
{int point_num = 0;cin >> point_num;//times的first和second用来存放寻找割点时保存的back值和discovertimepair<int, int>* times = new pair<int, int>[point_num];//每个点能到达的其他点vector<int>* g = new vector<int>[point_num];int in = 0;int out = 0;while (cin >> in && cin >> out) {g[in].emplace_back(out);g[out].emplace_back(in);}//DFS寻找割点int time = 0;vector<int> result;int treenum = 0;DFS_find_cutvertex(g,0,time, times, result,treenum,-1);if (treenum >= 2)result.emplace_back(0);sort(result.begin(),result.end());//将节点全部染成白色.时间重置for (auto i = 0; i < point_num; i++) {times[i].first = 0;times[i].second = 0;}    //DFS寻找桥int time2 = 0;vector<pair<int,int>> result2;DFS_find_bridge(g, 0, time2, times, result2, -1);sort(result2.begin(), result2.end());cout << "wo yi yue du guan yu chao xi de shuo ming" << endl;for (auto i = 0 ;i<result.size();i++)cout << int(result[i]) << endl;for (auto i = 0; i < result2.size(); i++) {cout << int(result2[i].first) << " " << int(result2[i].second) << endl;}delete []times;delete []g;return 0;
}

问题 B: 任务调度问题

时间限制: 1 Sec  内存限制: 5 MB
提交: 168  解决: 39
提交 状态 算法问答 

题目描述


请大家在做oj题之前,仔细阅读关于抄袭的说明http://www.bigoh.net/JudgeOnline/.

算法助教实在是太忙了,每天有n个事情要做,但他觉得自己一件一件的做实在是太蠢了,所以想找一些班上的同学来帮忙一块做这些事。

在分配任务的过程中他发现,这n个任务中有一些任务的开始需要依赖另一些任务的完成,例如,当只有先批改完算法作业(记为事件A),才能给大家登记作业成绩(记为事件B),这时我们就可称事件B依赖于事件A。机智的他利用了算法课上的知识,采用有向图中的节点来表示这些事件,并且利用图中的边来表示这些事件的依赖关系,例如,当事件B依赖于事件A时,图中就存在一条由B指向A的边。助教还对这样的有向图进行了升级,用节点的权值表示完成每个事件所需要的时间。

然而,随后他发现,由于图中依赖关系的存在,即使他利用庞大的关系网能找来无穷多个同学帮他做这些事,完成所有事件的最短时间也是确定的。那么问题来了,助教每天要花多少时间来处理这n个事情呢?这时,助教想起了算法课上学到的关键路径的定义似乎能够帮他解决这个问题。聪明的同学们,你们能告诉助教他即使找到帮手,每天做完这n个事情最短也需要花多长时间吗?

(善良的助教已经帮你们把这些事情建模成有向图,如输入所示。)



输入


第一行为图中的顶点个数n

第二行至第n+1行为每个顶点代表的事件编号(事件编号为1至n)及完成该事件所需的时间。 如,“1 50”代表完成事件1需要50个单位时间。

余下的行中,每一行表示一个依赖关系,例如,“1 3” 表示事件1的完成依赖于事件3的完成。



输出

这次依旧需要大家输出一行字符串,它还是“我已阅读关于抄袭的说明”的英文翻译,即:"I have read the rules about plagiarism punishment"。输出此行的提交我们将认为已经完全阅读并了解了“关于抄袭的说明”公告并同意关于抄袭的惩罚措施。

第二行输出完成所有这n个任务所需最短的执行时间。

样例输入

9
1 10
2 6
3 5
4 1
5 2
6 3
7 4
8 9
9 1
1 9
2 1
2 8
3 5
3 6
3 7
4 2
4 3
5 9
6 9
7 9
8 9

样例输出

I have read the rules about plagiarism punishment
18

提示

如果这些事情出现了循环依赖,则助教永远也不可能做完这些事(好惨 TAT)。所以你可以大胆假定,助教要做的这些事情中并不存在循环依赖,也就是说,输入的图一定是一个有向无环图。

答案

算法同样在书上有,就不多说了。

这里需要注意的就是在DFS上需要加wapper,遍历每个节点,找出最大的最早结束时间,注意,在遍历完一个节点后,不要清除visited和时间内容,这样遍历下一个节点时能减少工作量。

具体各对象的实现就看代码吧

#include <iostream>
#include <map>
#include <set>
#include <vector>
#include <algorithm>
using namespace std;//g表示图,point表示遍历开始节点,times表示各点最早开始结束时间,visited表示节点访问状态,result表示最大的最早结束时间
void DFS_critical_path(vector<int>* g, int point, pair<int, int>* times, vector<int>& visited, vector<int>& cost) {visited[point] = 1;times[point].first = 0;for (auto i = g[point].begin(); i != g[point].end(); i++) {if (visited[*i] == 0) {DFS_critical_path(g, *i, times,visited,cost);if (times[*i].second >= times[point].first) {times[point].first = times[*i].second;}}else {if (times[*i].second >= times[point].first) {times[point].first = times[*i].second;}}}//节点染成黑色times[point].second = times[point].first + cost[point];visited[point] = 2;
}int main() 
{int point_num = 10;cin >> point_num;vector<int> cost(point_num,0);int num = 0;int c = 0;//v[i].first表示最早开始时间,v[i].second表示最早结束时间pair<int, int>* times = new pair<int, int>[point_num];//visited[i] == 0表示节点未访问,visited == 1 表示节点正在访问,visited == 2表示访问结束vector<int> visited(point_num, 0);////path[i] == 0表示i不是关键路径,path[i] == 1表示i是关键路径//vector<int> path(point_num, 0);//获取每个事件的花费for (int i = 0; i < point_num; i++) {cin >> num;cin >> c;cost[i] = c;}//将A依赖于B表示成图中有B到A的单向边,g[i]表示点i能到达的所有点vector<int>* g = new vector<int>[point_num];while (cin >> num && cin >> c) {//输入是从1开始,但数组索引是从0开始g[num-1].emplace_back(c-1);}/*cost = {10,6,5,1,2,3,4,9,1,20};g[0] = {8};g[1] = {0,7};g[2] = {4,5,6};g[3] = {1,2};g[4] = {8};g[5] = {8};g[6] = {8};g[7] = {8};g[8] = {};g[9] = { 7 };begin[3] = 1;begin[9] = 1;*///DFS遍历,从所有节点都做一遍DFS,找出最大的最晚结束时间int result = 0;for (int i = 0; i < point_num; i++) {DFS_critical_path(g, i, times, visited, cost);if (times[i].second > result)result = times[i].second;}cout << "I have read the rules about plagiarism punishment" << endl;cout << result << endl;delete[]times;delete[]g;
}

转载于:https://www.cnblogs.com/likaiming/p/9053405.html

相关文章:

小程序生命周期_来,简单说说小程序的生命周期?

简单说说小程序的生命周期?在小程序中生命周期分为三大类应用生命周期页面生命周期组件生命周期应用生命周期onLaunch(){ console.log(onLaunch监听小程序初始化);}onShow(){ console.log(onShow监听小程序显示);}onHide() { console.log(onLaunch监听小程序隐藏);}页面生命周…

模板引擎:VelocityFreeMarker(转)

Velocity&#xff0c;名称字面翻译为&#xff1a;速度、速率、迅速&#xff0c;用在Web开发里&#xff0c;用过的人可能不多&#xff0c;大都基本知道和在使用Struts&#xff0c;到底Velocity和Struts(Taglib和Tiles)是如何联系&#xff1f;在技术上Velocity要比Struts Struts(…

去中心化的尺度

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 摘要&#xff1a;有些人因为其底层技术而对区块链感兴趣&#xff0c; 另外一些人对它的商业可能性着迷&#xff0c; 还有一些人关心它的社会和政治影…

在tomcat中用jndi配置数据源启动java web程序

1.在web.xml中添加: <resource-ref> <res-ref-name>jdbc/MTSDB</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth> </resource-ref> 2.在tomcat的context.xml中配置数据源:…

centOS7.4服务器 yum安装 搭建lamp环境

// 红色加粗是linux命令安装gcc和gcc-cyum -y install gcc gcc-cyum list httpd*安装apcheyum -y install httpd.x86_64 httpd-devel.x86_64 httpd-tools.x86_64开启服务/bin/systemctl start httpd.service停止服务/bin/systemctl stop httpd.service设置Apache服务开机启动sy…

好想学python怎么猜人_学手艺我好想学个手艺哦可是脑子怎么想也想 – 手机爱问...

2009-03-25学点东西学什么好呢&#xff1f;我今年快40了建议&#xff1a;你以前一直当销售&#xff0c;销售这个职业最大的特点就是说、说、说&#xff0c;跟人打交道最多。那么&#xff1a;(1)如果你厌倦了跟人打交道&#xff0c;厌烦了每天不停跟陌生人说说说的&#xff0c;建…

用Python从零开始创建区块链

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 前言 如果你还没有听说过 3 点钟区块链群&#xff0c;说明你还不是链圈的人&#xff1b;如果你还没有加入 3 点钟区块链群&#xff0c;说明你还不是…

动态添加跨行表格_学会这2招,轻松搞定数据透视表动态更新,效率猛增一倍...

私信回复关键词【福利】&#xff0c;获取丰富办公资源&#xff0c;助你高效办公早下班&#xff01;Hello&#xff0c;大家好&#xff0c;我是最近在研究数据透视表的小爽~最近&#xff0c;我收到了一个学员的求助&#xff1a;简单归纳一下&#xff0c;这个问题就是&#xff1a;…

alpha阶段个人总结(201521123031林庭亦)

一、个人总结 第一部分&#xff1a;硬的问题 第二部分&#xff1a;软的问题&#xff0c;在成长路上学到了什么&#xff1f; 1 当你看到不靠谱的设计、糟糕的代码、过时的文档和测试用例的时候&#xff0c;不要想 “既然别人的代码已经这样了&#xff0c;我的代码也可以随便一点…

python统计列表内元素个数

代码如下&#xff1a; list01 [a,b,c,a,c] set01 set(list01)print(set01)dict01 {}for item in set01:dict01.update({item:list01.count(item)}) print(dict01)结果&#xff1a; c, b, a} {c: 2, b: 1, a: 2}转载于:https://www.cnblogs.com/zhangyux/p/5999109.html

比特币的货币属性是什么?

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 作为比特币被设计之初的用意就是作为交易的一种支付手段。作为全新的货币形式&#xff0c;比特币本身的性质就是其去中心化的特性能够和传统的货币很…

病虫害模型算法_基于深度学习的目标检测算法综述

sigai 基于深度学习的目标检测算法综述导言目标检测的任务是找出图像中所有感兴趣的目标&#xff08;物体&#xff09;&#xff0c;确定它们的位置和大小&#xff0c;是机器视觉领域的核心问题之一。由于各类物体有不同的外观&#xff0c;形状&#xff0c;姿态&#xff0c;加上…

windows 常用命令

一. 工具类 calc 启动计算器 mspaint 画图板 write 打开写字板 notepad 打开记事本 mstsc 远程桌面连接 regedt32 注册表编辑器 osk 打开屏幕键盘 magnify 放大镜 eudcedit 造字程序二. 系统和用户类 compmgmt.msc 计算机管理 devmgmt.m…

良好的用户体验应该...

这篇文章只有一个图片&#xff0c;原创的&#xff0c;谢谢&#xff01; 转载于:https://www.cnblogs.com/saper/p/9064601.html

区块链知识点简解

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。 分布式存储&#xff1a;是一种数据存储技术&#xff0c;通…

laravel和dingoapi的结合使用

dingoapi是一个laravel的开源插件&#xff0c;可以在github上搜索到&#xff0c;现在在做一个项目&#xff0c;项目中总是会有后端跟前端的json数据交互&#xff0c;而这个dingoapi为json交互提供了很大的便利。 先安装dingoapi 1、在composer.json中的require中添加"ding…

uc的剪切板能关掉吗_关掉网络游戏,小孩就有美好的未来吗?

“关掉&#xff0c;关掉&#xff01;一定要关掉&#xff01;再不关掉那些网络游戏&#xff0c;小孩哪有美好的未来&#xff0c;哪有美好的前程&#xff0c;祖国哪有栋梁之才。”最近&#xff0c;一条魔性的小视频在网上刷屏。这条小视频里&#xff0c;一个小女孩用朗诵腔调大喊…

2017-2018-2 20165236 实验四《Android开发基础》实验报告

2017-2018-2 20165236 实验四《Android开发基础》实验报告 一、实验报告封面 课程&#xff1a;Java程序设计 班级&#xff1a;1652班 姓名&#xff1a;郭金涛 学号&#xff1a;20165236 指导教师&#xff1a;娄嘉鹏 实验日期&a…

区块链4.0DexChain是什么?

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 为了更好的理解Eos-DexChain,我们了解一下区块链4.0的标准。 1&#xff09;零成本发token 零成本上交易所流通 3&#xff09;去中心化交易所会借助…

Linux内核情景分析之异常访问,用户堆栈的扩展

情景假设&#xff1a;在堆内存中申请了一块内存&#xff0c;然后释放掉该内存&#xff0c;然后再去访问这块内存。也就是所说的野指针访问。当cpu产生页面错误时,会把失败的线性地址放在cr2寄存器.线性地址缺页异常的4种情况1.如果cpu访问的行现地址在内核态,那么很可能访问的是…

系统性能测试方案

转载&#xff1a;http://www.cnblogs.com/yunman/articles/5482134.html 1引言 1.1编写目的 编写本方案的目的是用于指导XXXX系统的性能测试,主要从测试环境、测试工具、测试策略、测试具体执行方法、任务与进度表等事先计划和设计。 1.2适用范围 XXXX系统性能测试组 XXXX系统开…

python跨行字符串 变量_在Python中有没有在多行字符串中使用变量的方法?

所以我把这个作为邮件发送脚本的一部分&#xff1a;try:content ("""From: Fromname To: Toname MIME-Version: 1.0Content-type: text/htmlSubject: testThis is an e-mail message to be sent in HTML formatThis is HTML message.This is headline."&q…

Python中的pickle模块

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 Pickle模块的作用 Pickle模块用于将python对象序列化为字节流&#xff0c;可存储在文件或数据库中&#xff0c;也可同通过网络进行传输。使用反序列…

pytorch python区别_pytorch源码解析:Python层 pytorchmodule源码

尝试使用了pytorch&#xff0c;相比其他深度学习框架&#xff0c;pytorch显得简洁易懂。花时间读了部分源码&#xff0c;主要结合简单例子带着问题阅读&#xff0c;不涉及源码中C拓展库的实现。一个简单例子实现单层softmax二分类&#xff0c;输入特征维度为4&#xff0c;输出为…

在vue中使用babel-polyfill

在 Vue.js项目中使用Vuex&#xff0c;Vuex 依赖 Promise&#xff0c;所以如果你的浏览器没有实现 Promise (比如 IE)&#xff0c;那么就需要使用一个 polyfill 的库 我们可以通过babel-profill转译 1、安装 npm install --save-dev babel-polyfill 2、在main.js中引入 import b…

CoinMarketCap计划于11月发布新的流动性排名系统

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 去中心化金融&#xff08;DeFi&#xff09;引领未来金融发展趋势&#xff0c;InvestDigital联合传统金融机构&#xff0c;依托现有数字货币金融业务…

cookie和session的代码实现

cookie和session的代码实现 1、设置cookie 今天笔试题考的是cookie的设置&#xff0c;我竟然选了request也可以设置cookie&#xff0c;我的天呀。 我们来看如何在response设置吧 public void service(HttpServletRequest req,HttpServletResponse resp) throws ServletExceptio…

idea 批量修改同一列_学会这个,1秒就可以批量处理文件

【问题1】根据公司名称&#xff0c;批量创建文件夹拿到老板给到的这个任务后&#xff0c;没关系我很有耐心&#xff0c;不就是右击新建文件夹重命名保存吗&#xff0c;然后加班点鼠标到天荒地老&#xff0c;终于完成了。结果老板说有些公司名有误要改正过来&#xff0c;还有几百…

动态规划和分治法的区别

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 动态规划也是一种分治思想&#xff08;比如其状态转移方程就是一种分治&#xff09;&#xff0c;但与分治算法不同的是&#xff0c;分治算法是把原问…

关于链式前向星。

一些代码 理解 #include<bits/stdc.h> using namespace std; //优先队列优化的链式前向星 const int maxn1000; const int INF0x3fffffff; struct Edge{int from, to, dist;Edge(int u, int v, int d):from(u),to(v),dist(d){} }; struct HeapNode{int u, d;HeapNode(int…