news 2026/5/12 8:01:31

UVa 140 Bandwidth

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
UVa 140 Bandwidth

题目分析

问题背景

给定一个无向图(V,E)(V, E)(V,E),其中VVV是结点集合,EEE是边集合。现要求给出结点的一个排列(ordering\texttt{ordering}ordering),使得这个排列的“带宽”(bandwidth\texttt{bandwidth}bandwidth)最小。具体定义如下:

  • 对于排列中的每个结点vvv,其带宽定义为vvv与其所有邻接结点在排列中的位置距离的最大值。
  • 整个排列的带宽定义为所有结点带宽的最大值。

例如,题目图示中给出了两种排列方式,带宽分别为666555,目标是找出所有排列中带宽最小的那一个。

输入格式

输入由多组数据组成,每组数据一行,以#结束。每组数据由若干个记录组成,记录之间用分号分隔。每个记录的格式为:

结点:邻居1邻居2...

结点用单个大写字母A-Z表示,图中结点数不超过888个。

输出格式

对于每组数据,输出一行,内容为:

结点1 结点2 ... 结点n -> 带宽

若有多个排列带宽相同,输出字典序最小的那一个。


解题思路

关键约束

  • 结点数≤8\leq 88
  • 带宽定义为排列中任意两个相邻结点之间的最大距离
  • 需要输出字典序最小的最优解。

可行解法

由于结点数最多为888,可以枚举所有可能的排列,计算每个排列的带宽,并记录最小值。结点数888的全排列共有8!=403208! = 403208!=40320种,计算每个排列的带宽是可行的。

算法步骤

  1. 读取一行输入,解析出所有结点及其邻接关系。
  2. 存储结点列表,并排序(为了后续按字典序生成排列)。
  3. 使用next_permutation枚举所有排列。
  4. 对于每个排列,遍历所有边,计算相邻结点在排列中的最大距离,即带宽。
  5. 记录带宽最小的排列,若带宽相同则保留字典序更小的。
  6. 输出结果。

时间复杂度

  • 枚举排列:O(n!)O(n!)O(n!)
  • 计算每个排列的带宽:O(n2)O(n^2)O(n2)(因为需检查所有结点对)
  • 总复杂度:O(n!⋅n2)O(n! \cdot n^2)O(n!n2),在n≤8n \leq 8n8时完全可行。

代码实现

// Bandwidth// UVa ID: 140// Verdict: Accepted// Submission Date: 2016-01-19// UVa Run Time: 0.079s//// 版权所有(C)2016,邱秋。metaphysis # yeah dot net#include<bits/stdc++.h>usingnamespacestd;string nodes;map<char,string>neighbours;intgetBandwidth(){intminBandwidth=1;for(inti=0;i<nodes.length()-1;i++)for(intj=i+1;j<nodes.length();j++)if(neighbours[nodes[i]].find(nodes[j])!=string::npos)if(abs(i-j)>minBandwidth)minBandwidth=abs(i-j);returnminBandwidth;}voidgetNeighbours(string record){for(inti=2;i<record.length();i++){neighbours[record[0]]+=record[i];neighbours[record[i]]+=record[0];}}intmain(){string line;while(getline(cin,line),line!="#"){nodes.clear();neighbours.clear();for(inti=0;i<line.length();i++)if(isalpha(line[i])&&nodes.find(line[i])==nodes.npos)nodes+=line[i];while(line.find(';')!=line.npos){getNeighbours(line.substr(0,line.find(';')));line=line.substr(line.find(';')+1);}getNeighbours(line);sort(nodes.begin(),nodes.end());intminBandwidth=7;string minSequences;minSequences.assign(nodes);do{intbandwidth=getBandwidth();if(bandwidth<minBandwidth){minSequences.assign(nodes);minBandwidth=bandwidth;}}while(next_permutation(nodes.begin(),nodes.end()));for(inti=0;i<minSequences.length();i++)cout<<minSequences[i]<<" ";cout<<"-> "<<minBandwidth<<"\n";}return0;}

总结

本题是一个典型的排列枚举 + 模拟计算问题,由于结点数限制很小,可以直接使用全排列暴力求解。注意在实现时要处理好输入解析和字典序比较的细节。

如果你对图论和排列枚举类问题感兴趣,可以进一步学习回溯剪枝启发式搜索(如模拟退火、遗传算法)在更大规模问题上的应用。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/9 22:47:10

导师推荐!10个AI论文网站测评:本科生毕业论文全攻略

导师推荐&#xff01;10个AI论文网站测评&#xff1a;本科生毕业论文全攻略 2026年AI论文写作工具测评&#xff1a;精准匹配本科生需求 随着人工智能技术的快速发展&#xff0c;越来越多的学术辅助工具被应用于论文写作过程中。对于本科生而言&#xff0c;从选题、文献检索到内…

作者头像 李华
网站建设 2026/5/10 10:36:26

机器学习在灾难信息筛选中发挥关键作用

在灾难期间寻找关键信息 莉斯圣丹尼斯是科罗拉多大学地球实验室的研究科学家&#xff0c;她指出社交媒体在风暴、野火、洪水和飓风等自然灾害中可能很有用&#xff0c;因为快速、本地化的信息在这些情况下至关重要。然而&#xff0c;将真正有用的信息与噪音区分开来是关键&…

作者头像 李华
网站建设 2026/5/10 4:59:38

零基础教程:用Ollama快速部署translategemma-4b-it翻译模型

零基础教程&#xff1a;用Ollama快速部署translategemma-4b-it翻译模型 你是不是也遇到过这些情况&#xff1a; 想把一张外文商品图快速转成中文说明&#xff0c;却要反复截图、复制、打开网页翻译&#xff1b; 收到一封英文技术文档邮件&#xff0c;逐句查词耗时又容易漏掉关…

作者头像 李华
网站建设 2026/5/10 6:09:30

亲测Fun-ASR语音转写效果,中文识别准确率实测分享

亲测Fun-ASR语音转写效果&#xff0c;中文识别准确率实测分享 最近在做会议纪要自动化和客服录音分析&#xff0c;试了市面上七八个语音转文字工具&#xff0c;有的识别快但错字多&#xff0c;有的支持热词却卡顿严重&#xff0c;直到遇到 Fun-ASR——这个由钉钉联合通义实验室…

作者头像 李华
网站建设 2026/5/11 15:19:48

3.2 Kubernetes集群搭建实战:kubeadm一键部署生产级集群

Kubernetes集群搭建实战:kubeadm一键部署生产级集群 引言 搭建 Kubernetes 集群是学习容器编排的第一步。kubeadm 是官方推荐的集群部署工具,本文将手把手教你使用 kubeadm 部署一个生产级的 Kubernetes 集群,包括单节点和多节点集群的完整配置。 一、环境准备 1.1 系统…

作者头像 李华