news 2026/4/23 13:05:03

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/4/23 3:43:12

TurboDiffusion在社交媒体内容创作的应用,方案详解

TurboDiffusion在社交媒体内容创作的应用&#xff0c;方案详解 1. 社交媒体内容创作的痛点与TurboDiffusion的破局点 你有没有经历过这样的时刻&#xff1a;为一条短视频绞尽脑汁构思脚本&#xff0c;反复修改提示词&#xff0c;等了整整三分钟&#xff0c;结果生成的视频模糊…

作者头像 李华
网站建设 2026/4/23 5:14:46

如何准备Qwen3-1.7B微调数据集?手把手教学

如何准备Qwen3-1.7B微调数据集&#xff1f;手把手教学 微调大模型的第一步&#xff0c;往往不是写代码&#xff0c;而是准备好能让模型真正学会“说话”的数据。很多人卡在微调环节&#xff0c;不是因为不会调参&#xff0c;而是数据集没理清楚&#xff1a;格式不对、结构混乱…

作者头像 李华
网站建设 2026/4/20 5:54:47

ChatGLM-6B场景扩展:插件化功能增强可能性探讨

ChatGLM-6B场景扩展&#xff1a;插件化功能增强可能性探讨 1. 为什么需要给ChatGLM-6B“加点料” 你有没有遇到过这样的情况&#xff1a;用ChatGLM-6B聊得正起劲&#xff0c;突然想查天气、算个数、翻译一段外文&#xff0c;或者把刚聊的内容生成一份总结——结果发现模型只能…

作者头像 李华
网站建设 2026/4/19 18:19:26

用Mamba模型轻松搞定超长文本处理

&#x1f493; 博客主页&#xff1a;借口的CSDN主页 ⏩ 文章专栏&#xff1a;《热点资讯》 用Mamba模型轻松搞定超长文本处理目录用Mamba模型轻松搞定超长文本处理 引言&#xff1a;长文本处理的“算力悬崖”与破局曙光 一、技术内核&#xff1a;为何Mamba能“轻装上阵”处理超…

作者头像 李华
网站建设 2026/4/19 0:21:31

opencode MIT协议解读:商业使用合规性与风险规避

opencode MIT协议解读&#xff1a;商业使用合规性与风险规避 1. OpenCode 是什么&#xff1f;终端里的“自由编程伙伴” OpenCode 不是一个玩具项目&#xff0c;而是一个真正能进生产线的 AI 编程助手。它诞生于 2024 年&#xff0c;用 Go 语言写成&#xff0c;从第一天起就带…

作者头像 李华