中文翻译:

但是,唉!一天,项链被撕破了,珠子散落在屋檐上。我姐姐尽力把地板上的珠子都捡起来了。但她不确定自己是否能收集到所有的照片。现在,她来找我帮忙。她想知道是否有可能让克劳斯使用她在里面的所有珠子,请帮助我写一个程序来解决这个问题。输入这个输入包含t’测试用例。输入的第一行包含整数。bead的数目每个测试用例的第一行包含一个整数n(5<n 1000),因为我妹妹可以收集。接下来的n行中的每一行都包含两个描述珠子颜色的整数。颜色由从1到50的整数表示,对于输入中的每个测试用例,首先输出示例输出中显示的测试用例编号。如果你觉得有些珠子可能会丢失,那就打印出来,这些珠子本身可能会丢失。否则,在每行上打印n行,并使用单珠说明。每个珠在一条线上。否则,在每行上打印n行,并使用单珠说明。每个beadDescription由两个整数组成,给出其两端的颜色。对于1<i<n1,第二行整数i必须与linn上的第一个整数相同,并且必须等于第1行上的第一个整数。由于有许多解决方案,因此其中任何一个都是可接受的,在两个连续的测试用例之间打印一个空白行s25le22356522233示例输出

package com.liuzhen.practice;

import java.util.ArrayList;
import java.util.Scanner; public class Main {
public static int MAX = 1000;
public static int start, count;
public static int num = 0;
public static int[] id = new int[MAX];
public static int[] degree = new int[MAX]; //用于计算给定图每个顶点的度
public static boolean[] used = new boolean[MAX]; //用于判断图中相应边是否被遍历
public static String[] path = new String[MAX];
public static ArrayList<String> result = new ArrayList<String>(); static class edge {
public int a; //边的起点
public int b; //边的终点
public int num; //边的编号 public edge(int a, int b, int num) {
this.a = a;
this.b = b;
this.num = num;
} public String getAB() {
return a + " "+ b;
}
}
//寻找顶点a的根节点
public int find(int[] id, int a) {
int root = a;
while(id[root] >= 0) {
root = id[root];
}
int i;
int k = a;
while(k != root) {
i = id[k];
id[k] = root;
k = i;
}
return root;
}
//合并顶点a和顶点b所在的树
public void union(int[] id, int a, int b) {
int rootA = find(id, a);
int rootB = find(id, b);
if(rootA == rootB)
return;
int rootNum = id[rootA] + id[rootB];
if(id[rootA] < id[rootB]) {
id[rootB] = rootA;
id[rootA] = rootNum;
} else{
id[rootA] = rootB;
id[rootB] = rootNum;
}
return;
} public void init() {
count = 0;
for(int i = 0;i < 51;i++) {
id[i] = -1; //初始化所有顶点所在树的根节点编号为-1
degree[i] = 0;
}
for(int i = 0;i < MAX;i++) {
used[i] = false;
path[i] = "";
}
return;
} public boolean judge(ArrayList<edge>[] map) {
int root = find(id, start);
for(int i = 0;i < map.length;i++) {
for(int j = 0;j < map[i].size();j++) {
if(root != find(id, map[i].get(j).b))
return false;
}
}
for(int i = 0;i < degree.length;i++) {
if(degree[i] % 2 != 0)
return false;
}
return true;
} public void dfs(ArrayList<edge>[] map, int start) {
for(int i = 0;i < map[start].size();i++) {
if(!used[map[start].get(i).num]) {
used[map[start].get(i).num] = true;
path[count++] = map[start].get(i).getAB();
dfs(map, map[start].get(i).b);
}
}
} public static void main(String[] args) {
Main test = new Main();
Scanner in = new Scanner(System.in);
int t = in.nextInt(); //总共要输入的图的数目
while(t > 0) {
t--;
@SuppressWarnings("unchecked")
ArrayList<edge>[] map = new ArrayList[51];
for(int i = 0;i < 51;i++)
map[i] = new ArrayList<edge>();
int k = in.nextInt(); //一次输入图的边数目
test.init();
for(int i = 0;i < k;i++) {
int a = in.nextInt();
int b = in.nextInt();
map[a].add(new edge(a, b, num));
map[b].add(new edge(b, a, num++));
degree[a]++;
degree[b]++;
test.union(id, a, b);
start = a;
}
String temp = "";
if(test.judge(map)) {
test.dfs(map, start);
for(int i = 0;i < k;i++) {
temp = temp + path[i] + "\n";
}
} else {
temp = "some beads may be lost";
}
result.add(temp);
}
for(int i = 0;i < result.size();i++) {
System.out.println("Case #"+(i+1));
System.out.println(result.get(i)+"\n");
}
}
}

运行结果:

5
2
3
4
5
6
2 1
2
4
1
4
Case #1
some beads may be lost Case #2
1
3
4
2
2

Java实现构造无向图的欧拉回路( The Necklace)的更多相关文章

  1. 算法笔记_143:构造无向图的欧拉回路(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 具体链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Item ...

  2. hdu 1878 无向图的欧拉回路

    原题链接 hdu1878 大致题意: 欧拉回路是指不令笔离开纸面,可画过图中每条边仅一次,且可以回到起点的一条回路.现给定一个无向图,问是否存在欧拉回路? 思路: 无向图存在欧拉回路的条件:1.图是连 ...

  3. SGU---101 无向图的欧拉回路

    题目链接: https://cn.vjudge.net/problem/SGU-101 题目大意: 给定你n张骨牌,每张牌左右两端有一个数字,每张牌的左右两端数字可以颠倒,找出一种摆放骨牌的顺序,使得 ...

  4. 算法笔记_142:无向图的欧拉回路求解(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 John's trip Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8 ...

  5. 算法笔记_141:无向图的欧拉回路判断问题(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 Problem Description 欧拉回路是指不令笔离开纸面,可画过图中每条边仅一次,且可以回到起点的一条回路.现给定一个图,问是否存在欧拉回 ...

  6. UVA 10054 The Necklace (无向图的欧拉回路)

    本文链接:http://www.cnblogs.com/Ash-ly/p/5405904.html 题意: 妹妹有一条项链,这条项链由许多珠子串在一起组成,珠子是彩色的,两个连续的珠子的交汇点颜色相同 ...

  7. Java实现无向图的欧拉回路判断问题

    1 问题描述 Problem Description 欧拉回路是指不令笔离开纸面,可画过图中每条边仅一次,且可以回到起点的一条回路.现给定一个图,问是否存在欧拉回路? Input 测试输入包含若干测试 ...

  8. 如何在 Java 中实现无向图

    基本概念 图的定义 一个图是由点集 \(V=\{v_i\}\) 和 \(V\) 中元素的无序对的一个集合 \(E=\{e_k\}\) 所构成的二元组,记为 \(G=(V,E)\),\(V\) 中的元素 ...

  9. poj2513Colored Sticks(无向图的欧拉回路)

    /* 题意:将两端涂有颜色的木棒连在一起,并且连接处的颜色相同! 思路:将每一个单词看成一个节点,建立节点之间的无向图!判断是否是欧拉回路或者是欧拉路 并查集判通 + 奇度节点个数等于2或者0 */ ...

随机推荐

  1. 网络编程采用HttpClient类更好

    一般人网络编程普遍用HttpWebRequest,类似下面的实现.我也一般都这样实现 string result = string.Empty; HttpWebRequest request = (H ...

  2. Vuser发生器

    一.脚本开发过程: 1.计划:收集测试信息,整理业务逻辑,制定测试计划 2.录制脚本: 新建脚本---选择脚本协议(单协议脚本:多协议脚本:最近使用过协议)选择协议---开始录制脚本 脚本录制时,Vu ...

  3. IP协议及其它的小弟 ,我保证没人会看的

    IP协议及其它的小弟 IP协议:127.0.0.1就一个32位的标识符.实际上: 类似这样的: 精神小伙慢慢看吧.我赌一包辣条你是不会认真看完的. IP协议的构成 地址解析协议 ARP 前面的叙述中我 ...

  4. React:Element

    React Elements 是构成React App的最小单位.React中的组件是由一个或多个Elements构成的. 和DOM不同,React Elements 是纯粹的JS对象.利用React ...

  5. Java Web项目部署到阿里云服务器(ECS)

    本篇随笔只是记录博主第一次将自己的Java项目部署到阿里云服务器的大致过程,具体细节还请参考别的博文. 一.项目介绍 我做的项目是利用maven项目构建工具进行搭建基于SSM框架的代码共享管理系统,主 ...

  6. docker基本维护命令

    docker search centos ##查服务器上面的镜像:docker images ##查本地的镜像.docker pull centos ##拉镜像. docker run centos ...

  7. spring源码解析-ApplicationContext解析

    ApplicationContext和BeanFactory一样都是bean的容器,而BeanFactory是一切Bean容器的父类,ApplicationContext继承于BeanFactory( ...

  8. 加密通信软件Signal 2.92版本编译安装折腾手记(Ubuntu 18.04)

    加密通信软件Signal 2.92版本编译安装折腾手记(Ubuntu 18.04) 前言 加密通信软件Signal是开源的,安全性很高,号称斯诺登也推荐大家使用.既然这么好,那必然会有不少人去尝试复制 ...

  9. vue 使用cli脚手架手动创建项目 相关的选择配置及真正项目的开始

    转载https://www.jianshu.com/p/635bd3ab7383 根据上述连接将基本的环境和命令和装好 使用命令行  vue create 项目名称  出现选项  选择手动(没有截图展 ...

  10. 第11章 支撑向量机SVM

    Support Vector Machine ,  问题:如果决策边界不唯一 , , , , , , , ,  s.t.(such that):之前都是全局最优化问题,这次是有条件的最优化问题 har ...