数据结构算法需要解释
Datastructure algorithm needs an explanation
如何连接元组列表,使输入和输出看起来像:
Input: (5,4),(6,2),(9,3),(2,5),(4,9)
Output: (6,2),(2,5),(5,4),(4,9),(9,3)
元组的每个第二项对应下一个元组的第一项。
我想您希望以连接元组的方式替换输入索引。
这是一个工作示例,可以在很多方面进行改进,但我发帖是为了让您了解一般算法:
找到第一个元组 - 元组的左元素,其中没有其他元组具有相等的右元素。
查找下一个元组 - 左元素等于最后插入的元组右元素的元组,根据需要重复此步骤。
List<Tuple<int, int>> input = new List<Tuple<int, int>>
{
new Tuple<int, int>(5,4),
new Tuple<int, int>(6,2),
new Tuple<int, int>(9,3),
new Tuple<int, int>(2,5),
new Tuple<int, int>(4,9)
};
List<Tuple<int, int>> output = new List<Tuple<int, int>>();
void Main()
{
var firstTuple = input.First(item => !(input.Exists(item1 => item1.Item2 == item.Item1)));
output.Add(firstTuple);
AddNextTuple(output[0]);
AddNextTuple(output[1]);
AddNextTuple(output[2]);
AddNextTuple(output[3]);
// Output: (6,2),(2,5),(5,4),(4,9),(9,3)
}
void AddNextTuple(Tuple<int, int> current){
output.Add(input.First(item1 => input.Exists(item => item1.Item1 == current.Item2)));
}
如何连接元组列表,使输入和输出看起来像:
Input: (5,4),(6,2),(9,3),(2,5),(4,9)
Output: (6,2),(2,5),(5,4),(4,9),(9,3)
元组的每个第二项对应下一个元组的第一项。
我想您希望以连接元组的方式替换输入索引。
这是一个工作示例,可以在很多方面进行改进,但我发帖是为了让您了解一般算法:
找到第一个元组 - 元组的左元素,其中没有其他元组具有相等的右元素。
查找下一个元组 - 左元素等于最后插入的元组右元素的元组,根据需要重复此步骤。
List<Tuple<int, int>> input = new List<Tuple<int, int>>
{
new Tuple<int, int>(5,4),
new Tuple<int, int>(6,2),
new Tuple<int, int>(9,3),
new Tuple<int, int>(2,5),
new Tuple<int, int>(4,9)
};
List<Tuple<int, int>> output = new List<Tuple<int, int>>();
void Main()
{
var firstTuple = input.First(item => !(input.Exists(item1 => item1.Item2 == item.Item1)));
output.Add(firstTuple);
AddNextTuple(output[0]);
AddNextTuple(output[1]);
AddNextTuple(output[2]);
AddNextTuple(output[3]);
// Output: (6,2),(2,5),(5,4),(4,9),(9,3)
}
void AddNextTuple(Tuple<int, int> current){
output.Add(input.First(item1 => input.Exists(item => item1.Item1 == current.Item2)));
}