poj_3767——I Wanna Go Home

2024-01-04 09:48
文章标签 go poj home 3767 wanna

本文主要是介绍poj_3767——I Wanna Go Home,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

来源:http://poj.org/problem?id=3767

题目就不贴了,把代码和遇到的问题分享一下吧!

中间用G++交了很多次都是RE(运行错误),后来改用C++交发现还是有问题,一样的错误。这个程序中发现我写的一般都是用C++交比较牢靠,还有定义迪杰斯特拉 函数名的时候我用了个dijk(),然后我悲剧了,RE!你懂得,后来突发奇想改了一下交上去就AC了。郁闷死我啊!


呵呵,废话说完,下面说一下这个题,这个题目其实就是最短路的应用,在这里用的还是挺简单的,把迪杰斯特拉算法掌握就OK!

由于这个题中从1类城市走到2类城市后就不能再回去,只能穿过一次,所以先存为双向路,后面再根据不同类型的城市,把双向路变为单向路。

然后核心算法实现就OK!

代码:

#include<cstring>
#include<cstdio>
#include<iostream>
using namespace std;
#define inf 0xfffffff
#define size 610
int value[size][size];
int d[size];
int lead[size];
bool visit[size];
int n,m;
void djk()
{int x,y,z,tab,temp;memset(visit,0,sizeof(visit));for(x=1;x<=n;x++)d[x]=value[1][x];d[1]=0;visit[1]=1;for(x=1;x<n;x++){temp=inf;for(y=1;y<=n;y++){if(!visit[y]&&d[y]<temp){temp=d[y];tab=y;}}visit[tab]=true;for(z=1;z<=n;z++){if(!visit[z]&&d[z]>d[tab]+value[tab][z])d[z]=d[tab]+value[tab][z];}}if(d[2]==inf)cout<<"-1\n";elsecout<<d[2]<<endl;
}int main()
{while(cin>>n){if(n==0)break;int i,j,a,b,len;cin>>m;memset(lead,0,sizeof(lead));for(i=1;i<=n;i++)for(j=1;j<=n;j++)value[i][j]=inf;for(i=1;i<=m;i++){cin>>a>>b>>len;value[a][b]=value[b][a]=len;}for(i=1;i<=n;i++)cin>>lead[i];for(i=1;i<=n;i++){for(j=1;j<=n;j++){if(lead[i]!=lead[j]){if(lead[i]==1&&lead[j]==2)value[j][i]=inf;else if(lead[i]==2&&lead[j]==1)value[i][j]=inf;}}}djk();}return 0;
}
在执行后面双向图转换单向图时有另外一种方法,

但是交上去也是RE。

for(i=1;i<=n;i++){if(lead[i]==2){for(j=1;j<=n;j++){if(lead[j]==1)value[i][j]=inf;}}}

很悲剧啊!

这篇关于poj_3767——I Wanna Go Home的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/568931

相关文章

Go 语言中的select语句详解及工作原理

《Go语言中的select语句详解及工作原理》在Go语言中,select语句是用于处理多个通道(channel)操作的一种控制结构,它类似于switch语句,本文给大家介绍Go语言中的select语... 目录Go 语言中的 select 是做什么的基本功能语法工作原理示例示例 1:监听多个通道示例 2:带

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

go中空接口的具体使用

《go中空接口的具体使用》空接口是一种特殊的接口类型,它不包含任何方法,本文主要介绍了go中空接口的具体使用,具有一定的参考价值,感兴趣的可以了解一下... 目录接口-空接口1. 什么是空接口?2. 如何使用空接口?第一,第二,第三,3. 空接口几个要注意的坑坑1:坑2:坑3:接口-空接口1. 什么是空接

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

Go语言中最便捷的http请求包resty的使用详解

《Go语言中最便捷的http请求包resty的使用详解》go语言虽然自身就有net/http包,但是说实话用起来没那么好用,resty包是go语言中一个非常受欢迎的http请求处理包,下面我们一起来学... 目录安装一、一个简单的get二、带查询参数三、设置请求头、body四、设置表单数据五、处理响应六、超

Golang基于内存的键值存储缓存库go-cache

《Golang基于内存的键值存储缓存库go-cache》go-cache是一个内存中的key:valuestore/cache库,适用于单机应用程序,本文主要介绍了Golang基于内存的键值存储缓存库... 目录文档安装方法示例1示例2使用注意点优点缺点go-cache 和 Redis 缓存对比1)功能特性

Go 1.23中Timer无buffer的实现方式详解

《Go1.23中Timer无buffer的实现方式详解》在Go1.23中,Timer的实现通常是通过time包提供的time.Timer类型来实现的,本文主要介绍了Go1.23中Timer无buff... 目录Timer 的基本实现无缓冲区的实现自定义无缓冲 Timer 实现更复杂的 Timer 实现总结在

Go使用pprof进行CPU,内存和阻塞情况分析

《Go使用pprof进行CPU,内存和阻塞情况分析》Go语言提供了强大的pprof工具,用于分析CPU、内存、Goroutine阻塞等性能问题,帮助开发者优化程序,提高运行效率,下面我们就来深入了解下... 目录1. pprof 介绍2. 快速上手:启用 pprof3. CPU Profiling:分析 C

使用Go语言开发一个命令行文件管理工具

《使用Go语言开发一个命令行文件管理工具》这篇文章主要为大家详细介绍了如何使用Go语言开发一款命令行文件管理工具,支持批量重命名,删除,创建,移动文件,需要的小伙伴可以了解下... 目录一、工具功能一览二、核心代码解析1. 主程序结构2. 批量重命名3. 批量删除4. 创建文件/目录5. 批量移动三、如何安

Go路由注册方法详解

《Go路由注册方法详解》Go语言中,http.NewServeMux()和http.HandleFunc()是两种不同的路由注册方式,前者创建独立的ServeMux实例,适合模块化和分层路由,灵活性高... 目录Go路由注册方法1. 路由注册的方式2. 路由器的独立性3. 灵活性4. 启动服务器的方式5.