UVA - 140 Bandwidth(带宽)(全排列)
题意:给定图,求是带宽最小的结点排列。
分析:结点数最多为8,全排列即可。顶点范围是A~Z。
- #pragma comment(linker, "/STACK:102400000, 102400000")
- #include<cstdio>
- #include<cstring>
- #include<cstdlib>
- #include<cctype>
- #include<cmath>
- #include<iostream>
- #include<sstream>
- #include<iterator>
- #include<algorithm>
- #include<string>
- #include<vector>
- #include<set>
- #include<map>
- #include<stack>
- #include<deque>
- #include<queue>
- #include<list>
- #define Min(a, b) ((a < b) ? a : b)
- #define Max(a, b) ((a < b) ? b : a)
- typedef long long ll;
- typedef unsigned long long llu;
- const int INT_INF = 0x3f3f3f3f;
- const int INT_M_INF = 0x7f7f7f7f;
- const ll LL_INF = 0x3f3f3f3f3f3f3f3f;
- const ll LL_M_INF = 0x7f7f7f7f7f7f7f7f;
- const int dr[] = {, , -, , -, -, , };
- const int dc[] = {-, , , , -, , -, };
- const int MOD = 1e9 + ;
- const double pi = acos(-1.0);
- const double eps = 1e-;
- const int MAXN = + ;
- const int MAXT = + ;
- using namespace std;
- char s[MAXN];
- set<int> node[];
- vector<int> v;
- int t[];
- void init(){
- for(int i = ; i < ; ++i){
- node[i].clear();
- }
- v.clear();
- memset(t, , sizeof t);
- int len = strlen(s);
- for(int i = ; i < len; ++i){
- if(s[i] == ':'){
- int tmp = s[i - ] - 'A';
- while(){
- ++i;
- if(i == len) break;
- if(s[i] == ';') break;
- node[tmp].insert(s[i] - 'A');
- node[s[i] - 'A'].insert(tmp);
- }
- }
- }
- }
- int main(){
- while(scanf("%s", s) == ){
- if(s[] == '#') return ;
- init();
- for(int i = ; i < ; ++i){
- if(node[i].size()){
- v.push_back(i);
- }
- }
- int len = v.size();
- int ans = INT_M_INF;
- do{
- int tmp = ;
- for(int i = ; i < len; ++i){
- for(int j = ; j < i; ++j){
- if(node[v[i]].count(v[j])){
- tmp = max(tmp, i - j);
- }
- }
- }
- if(tmp < ans){
- ans = tmp;
- for(int i = ; i < len; ++i){
- t[i] = v[i];
- }
- }
- }while(next_permutation(v.begin(), v.end()));
- for(int i = ; i < len; ++i){
- printf("%c ", 'A' + t[i]);
- }
- printf("-> %d\n", ans);
- }
- return ;
- }
UVA - 140 Bandwidth(带宽)(全排列)的更多相关文章
- UVa OJ 140 - Bandwidth (带宽)
Time limit: 3.000 seconds限时3.000秒 Problem问题 Given a graph (V,E) where V is a set of nodes and E is a ...
- uva 140 bandwidth (好题) ——yhx
Bandwidth Given a graph (V,E) where V is a set of nodes and E is a set of arcs in VxV, and an orde ...
- UVA 140 Bandwidth (dfs 剪枝 映射)
题意: 给定一个n个结点的图G和一个结点的排列, 定义结点i的带宽b(i)为i和相邻结点在排列中的最远距离, 所有b(i)的最大值就是这个图的带宽, 给定G, 求让带宽最小的结点排列. 给定的图 n ...
- UVa 140 Bandwidth【枚举排列】
题意:给出n个节点的图,和一个节点的排列,定义节点i的带宽b[i]为i和其相邻节点在排列中的最远的距离,所有的b[i]的最大值为这个图的带宽,给一个图,求出带宽最小的节点排列 看的紫书,紫书上说得很详 ...
- UVA 140 Bandwidth
题意: 给出一个n个节点的图G,和一个节点的排列,定义节点i的带宽为i和相邻节点在排列中的最远距离,而所有带宽的最大值就是图的带宽,求让图的带宽最小的排列. 分析: 列出所有可能的排列,记录当前找到的 ...
- UVA 140 Brandwidth 带宽 (dfs回溯)
看到next_permutation好像也能过╮(╯▽╰)╭ 这题学习点: 1.建图做映射 2.通过定序枚举保证字典序最小 3.strtok,sscanf,strchr等函数又复习了一遍,尽管程序中没 ...
- UVa 140 (枚举排列) Bandwidth
题意较复杂,请参见原题=_=|| 没什么好说的,直接枚举每个排列就好了,然后记录最小带宽,以及对应的最佳排列. STL里的next_permutation函数真是好用. 比较蛋疼的就是题目的输入了.. ...
- UVa 140 带宽
题意:给出一个n个结点的图G和一个结点的排列,定义结点的带宽为i和相邻结点在排列中的最远距离,求出让带宽最小的结点排列. 思路:用STL的next_permutation来做确实是很方便,适当剪枝一下 ...
- 【例题 7-6 UVA - 140】Bandwidth
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 暴力做就好. O(8!*26^2) [代码] /* 1.Shoud it use long long ? 2.Have you ev ...
随机推荐
- Chrome 43+浏览器 Cookies encrypted_value解密脚本
python 3.3.5 # -*- coding: utf-8 -*- # Used information from: # http://stackoverflow.com/questions/4 ...
- chromium blog
http://blog.chromium.org/
- ratingbar设置不可调节星星数量
<RatingBar android:id="@+id/rb_bar" android:layout_width="wrap_content" andro ...
- 一段代码详解JavaScript面向对象
(function(){ //私有静态成员 var user = ""; //私有静态方法 function privateStaticMethod(){ } Box = func ...
- aapt: error while loading shared libraries: libstdc++.so.6: wrong ELF class: ELFCLASS64
前阵子在ubuntu上搭载安卓的开发环境(Eclipse+Sdk+Adt),搭载是完成了,但是却出现了该问题: aapt: error while loading shared libraries: ...
- adb not responding. if you'd like to
在安装genymotion后启动工程报此错误. 解决方案:把其他虚拟机删掉,然后用genymotion新建一个,启动工程OK.
- Qt5:窗口居中显示
QDesktopWidget* desktop = QApplication::desktop(); // =qApp->desktop();也可以move((desktop->width ...
- Qt5:QSystemTrayIcon类实现程序托盘图标
windows下,在许多应用程序中都会实现一个托盘图标,用于隐藏应用程序窗口时还能对该应用程序进行简单的操作,例如 QQ ,renren等程序 那么,在Qt中,如何实现呢? 这就要用到Qt提供的 QS ...
- mysql建表---级联删除
CREATE TABLE `roottb` ( `id` INT(11) UNSIGNED AUTO_INCREMENT NOT NULL, `data` VARCHAR(100) NOT NUL ...
- windows矢量字体点阵数据的提取(转)
源:windows矢量字体点阵数据的提取 问题参考:windows api 获取字库点阵的问题 1.提取原理 在windows系统当中提取矢量字体的字模有很多方法,下面介绍一种利用GetGlyphOu ...