2

我必须编写一个程序来接收多行输入,然后根据给定的几个命令行参数对它们进行排序。行可以是可变长度的,行上的每个项目都用逗号分隔,如下所示:

a,b,c,12,3
d,e,f,4,56
a,g,h,8,5

程序要做的是根据给定的参数对某些列上的输入进行排序。这很简单,但困难的部分是我还必须能够对多个参数进行排序。

例如,命令行参数 1,4(均为升序)将输出:

a,g,h,8,5
a,b,c,12,3
d,e,f,4,56

所以它根据第一列排序,然后是第四列。我不确定如何对某些内容进行排序,然后只使用下一个参数对冲突的元素进行排序,而不使用整个列。我目前将输入存储在向量向量中。

作为旁注,我已经阅读了一些类似的问题,但所有这些问题都只有一组要排序的东西。对于这个程序,每行的项目数可以从 1 开始,并且排序依据的参数数量也可以是可变的。

4

1 回答 1

1

首先,使用 std::sort() ,它首先与迭代器一起工作,最后作为输入。然后,使用递归。递归是解决方案的关键。

对于每个参数,即排序标准 C_i,您有一个递归级别 R_i。在每个递归级别 R_i 中,您有两个步骤:

  1. 根据标准 C_i 对给定的数据范围进行排序。
  2. 循环遍历数据范围。每当值 C_i 更改时,使用参数调用下一个递归级别 R_{i+1}:
    • first:指向最后一次更改的迭代器,或者,范围的开头
    • last:指向当前元素的迭代器(第一个改变 C_i 的元素)
    • 指向标准列表和 i+1 的引用/指针

而已!

讨论此解决方案:

  • 由于迭代器,这种方法是有效的,因为底层数据结构不需要重新初始化、复制等。
  • 您需要编写一个用 i 初始化的自定义比较器函子,并将始终根据向量的元素 i 进行比较。
  • 哪个更快是有争议的:做一个大排序,在每次比较中都必须通过所有排序标准,或者排序多次,就像我的方法一样,每次只检查一个标准。
  • 在这个解决方案中,很多向量被交换。然而这不是问题,因为 std::vector 交换很便宜。
于 2013-03-03T10:18:10.067 回答