http://acm.nyist.net/JudgeOnline/problem.php?pid=510

2024-01-10 07:32

本文主要是介绍http://acm.nyist.net/JudgeOnline/problem.php?pid=510,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题意中文不解释。。

思路:以每个物品当做图中的顶点,以优惠的价格为边权,建图,这里让求需要的最少金币,故可以转化为最短路问题,这里引入一个超级源点0,可以看做是每个物品都可以和自己交换,但没有优惠价格,当找不到可交换的物品时(只能和自己交换),则返回当前的最短路径长度,即是所需要的最少金币。

#include<iostream>
#include<vector>
#include<algorithm>
#include<string.h>
#include<queue>
#include<cstdio>
#define  N 105
using namespace std;
struct Gnode
{Gnode() {}Gnode(int len,int num):len(len),num(num) {}int len,num;
};
struct Gnode1
{Gnode1() {}Gnode1(int num,int dis,int maxlev,int minlev):num(num),dis(dis),maxlev(maxlev),minlev(minlev) {}int num,dis,maxlev,minlev;bool operator< (const Gnode1 &now) const{return now.dis<dis;}
};
int lev[N],dlev;
int dijkstra(vector<vector<Gnode> >&Graph)
{priority_queue<Gnode1> Q;Q.push(Gnode1(1,0,lev[1],lev[1]));while(1){Gnode1 cur=Q.top();if(cur.num==0) return cur.dis;for(int i=0;i<Graph[cur.num].size();++i){if(Graph[cur.num][i].num==0||(cur.maxlev-lev[Graph[cur.num][i].num]<=dlev&&lev[Graph[cur.num][i].num]-cur.minlev<=dlev)){int maxx=max(cur.maxlev,lev[Graph[cur.num][i].num]);int minx=min(cur.minlev,lev[Graph[cur.num][i].num]);Q.push(Gnode1(Graph[cur.num][i].num,cur.dis+Graph[cur.num][i].len,maxx,minx));}}Q.pop();}
}
int main()
{int n;while(cin>>dlev>>n&&dlev&&n){vector<vector<Gnode> >Graph (n+1);memset(lev,0,sizeof(lev));for(int i=1;i<=n;++i){int price,m;cin>>price>>lev[i]>>m;Graph[i].push_back(Gnode(price,0));for(int j=0;j!=m;++j){int a,b;cin>>a>>b;Graph[i].push_back(Gnode(b,a));}}cout<<dijkstra(Graph)<<endl;}return 0;
}



这篇关于http://acm.nyist.net/JudgeOnline/problem.php?pid=510的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C#借助Spire.XLS for .NET实现在Excel中添加文档属性

《C#借助Spire.XLSfor.NET实现在Excel中添加文档属性》在日常的数据处理和项目管理中,Excel文档扮演着举足轻重的角色,本文将深入探讨如何在C#中借助强大的第三方库Spire.... 目录为什么需要程序化添加Excel文档属性使用Spire.XLS for .NET库实现文档属性管理Sp

C#借助Spire.XLS for .NET实现Excel工作表自动化样式设置

《C#借助Spire.XLSfor.NET实现Excel工作表自动化样式设置》作为C#开发者,我们经常需要处理Excel文件,本文将深入探讨如何利用C#代码,借助强大的Spire.XLSfor.N... 目录为什么需要自动化工作表样式使用 Spire.XLS for .NET 实现工作表整体样式设置样式配置

C#利用Free Spire.XLS for .NET复制Excel工作表

《C#利用FreeSpire.XLSfor.NET复制Excel工作表》在日常的.NET开发中,我们经常需要操作Excel文件,本文将详细介绍C#如何使用FreeSpire.XLSfor.NET... 目录1. 环境准备2. 核心功能3. android示例代码3.1 在同一工作簿内复制工作表3.2 在不同

在.NET项目中嵌入Python代码的实践指南

《在.NET项目中嵌入Python代码的实践指南》在现代开发中,.NET与Python的协作需求日益增长,从机器学习模型集成到科学计算,从脚本自动化到数据分析,然而,传统的解决方案(如HTTPAPI或... 目录一、CSnakes vs python.NET:为何选择 CSnakes?二、环境准备:从 Py

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python