ACM-ICPC 2017 南宁赛区网络预赛 J  Minimum Distance in a Star Graph 【模拟+索引】

本文主要是介绍ACM-ICPC 2017 南宁赛区网络预赛 J  Minimum Distance in a Star Graph 【模拟+索引】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  •  1000ms
  •  262144K

In this problem, we will define a graph called star graph, and the question is to find the minimum distance between two given nodes in the star graph.

Given an integer nn, an n-dimensionaln−dimensional star graph, also referred to as Sn​, is an undirected graph consisting of n! nodes (or vertices) and ((n−1) ∗ n!)/2 edges. Each node is uniquely assigned a label x1​ x2​ ... xn​which is any permutation of the n digits1,2,3,...,n. For instance, an S4​ has the following 24 nodes 1234,1243,1324,1342,1423,1432,2134,2143,2314,2341,2413,2431,3124,3142,3214,3241,3412,3421,4123,4132,4213,4231,4312,4321. For each node with label x1​ x2​x3​ x4​ ... xn​, it has n-1n−1 edges connecting to nodes x2​ x1​ x3​ x4​ ... xn​,x3​ x2​ x1​ x4​ ... xn​,x4​ x2​ x3​ x1​ ... xn​, ..., and xn​ x2​ x3​ x4​ ... x1​. That is, the n−1 adjacent nodes are obtained by swapping the first symbol and the d-thd−th symbol of x1​ x2​ x3​ x4​ ... xn​, for d=2,...,n. For instance, in S4​, node 1234 has 3 edges connecting to nodes 2134, 3214, and 4231. The following figure shows how S4​ looks (note that the symbols a, b, c, and d are not nodes; we only use them to show the connectivity between nodes; this is for the clarity of the figure).

image

In this problem, you are given the following inputs:

  • nn: the dimension of the star graph. We assume that nn ranges from 44 to 99.
  • Two nodes x1​ x2​ x3​ ... xn​ and y1​ y2​ y3​ ... yn​ in Sn​.

You have to calculate the distance between these two nodes (which is an integer).

Input Format

nn (dimension of the star graph)

A list of 5 pairs of nodes.

Output Format

A list of 5 values, each representing the distance of a pair of nodes.

样例输入

4
1234 4231
1234 3124
2341 1324
3214 4213
3214 2143

样例输出

1
2
2
1
3

题目来源

2017 ACM-ICPC 亚洲区(南宁赛区)网络赛

题目大意:123...n的一个全排列作为一个结点的标识,一个结点可以通过长度为1的路径到达下一个结点,下一个结点是指此结点的标识的第一个数和后面任意一个数交换后的全排列,给你5组结点,每组2个结点,问从一个结点到另一个结点的最短路径

题解:用字符串标识结点,s1保持不变,将s2变为s1,由于只能将第一个数和后面的数交换,因此 需要这样考虑:
1.当s2[0]不等于s1[0]时,将s2[0]换到正确的位置 
2.当s2[0]等于s1[0]时,如果还不匹配,就将s2后面第一个不匹配的数和s2[0]交换 

AC的C++代码:

#include<iostream>
#include<string>using namespace std;int n;
bool fail(string s1,string s2)
{for(int i=0;i<n;i++)if(s1[i]!=s2[i])return true;return false;
}int main()
{int right[13]; string s1,s2;cin>>n;for(int i=1;i<=5;i++){cin>>s1>>s2;for(int j=0;j<n;j++)right[s1[j]-'0']=j;int ans=0;while(fail(s1,s2)){//如果不匹配就持续操作 if(s2[0]!=s1[0]){ans++;int k=right[s2[0]-'0'];//k为s2[0]应在的位置 swap(s2[0],s2[k]);}else{//找到第一个不匹配的位置jans++;int j; for(j=1;j<n&&j==right[s2[j]-'0'];j++);swap(s2[0],s2[j]);}}cout<<ans<<endl;}return 0;
}

 

这篇关于ACM-ICPC 2017 南宁赛区网络预赛 J  Minimum Distance in a Star Graph 【模拟+索引】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

MySQL中的索引结构和分类实战案例详解

《MySQL中的索引结构和分类实战案例详解》本文详解MySQL索引结构与分类,涵盖B树、B+树、哈希及全文索引,分析其原理与优劣势,并结合实战案例探讨创建、管理及优化技巧,助力提升查询性能,感兴趣的朋... 目录一、索引概述1.1 索引的定义与作用1.2 索引的基本原理二、索引结构详解2.1 B树索引2.2

python3如何找到字典的下标index、获取list中指定元素的位置索引

《python3如何找到字典的下标index、获取list中指定元素的位置索引》:本文主要介绍python3如何找到字典的下标index、获取list中指定元素的位置索引问题,具有很好的参考价值,... 目录enumerate()找到字典的下标 index获取list中指定元素的位置索引总结enumerat

从入门到精通MySQL 数据库索引(实战案例)

《从入门到精通MySQL数据库索引(实战案例)》索引是数据库的目录,提升查询速度,主要类型包括BTree、Hash、全文、空间索引,需根据场景选择,建议用于高频查询、关联字段、排序等,避免重复率高或... 目录一、索引是什么?能干嘛?核心作用:二、索引的 4 种主要类型(附通俗例子)1. BTree 索引(

MySQL 添加索引5种方式示例详解(实用sql代码)

《MySQL添加索引5种方式示例详解(实用sql代码)》在MySQL数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中,下面给大家分享MySQL添加索引5种方式示例详解(实用sql代码),... 在mysql数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中。索引可以在创建表时定义,也可

Python使用pynput模拟实现键盘自动输入工具

《Python使用pynput模拟实现键盘自动输入工具》在日常办公和软件开发中,我们经常需要处理大量重复的文本输入工作,所以本文就来和大家介绍一款使用Python的PyQt5库结合pynput键盘控制... 目录概述:当自动化遇上可视化功能全景图核心功能矩阵技术栈深度效果展示使用教程四步操作指南核心代码解析

Linux网络配置之网桥和虚拟网络的配置指南

《Linux网络配置之网桥和虚拟网络的配置指南》这篇文章主要为大家详细介绍了Linux中配置网桥和虚拟网络的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、网桥的配置在linux系统中配置一个新的网桥主要涉及以下几个步骤:1.为yum仓库做准备,安装组件epel-re

Python模拟串口通信的示例详解

《Python模拟串口通信的示例详解》pySerial是Python中用于操作串口的第三方模块,它支持Windows、Linux、OSX、BSD等多个平台,下面我们就来看看Python如何使用pySe... 目录1.win 下载虚www.chinasem.cn拟串口2、确定串口号3、配置串口4、串口通信示例5