c/c++语言开发共享将未排序的连续字符串数组有效地排序到文件中

我有一个包含无序连续数字的字符串数组(范围从0到n),例如[7a, 1b, 2c, 0d, 6e, 5f, 3g, 4h] ,我想将数字按顺序写入文件。

例如:

 0d 1b 2c 3g 4h 5f 6e 7a 

字符串的长度不尽相同。

我试图找到一种方法,既快速又无需占用太多​​空间。 我找到了一种方法,我可以在O(n)空间复杂度和O(n)性能中做到这一点:我创建一个包含n个单元格的数组,并将每个字符串插入到他的单元格编号中。

 for (i = 0; i < n; i++) sortedArray[originalArray[i]] = originalArray[i] 

…类似的东西(创建原始大小的新数组并在一次运行中填充),然后与另一个for循环将已排序数组的内容写入文件。

但我正在寻找一种更好的方法来做到这一点。

    假设你的字符串中的前导数字确实是连续且不重复的,那么你将无法获得比你在问题中描述的方法更好的时间复杂度,或者沿着这些方向的东西。 它需要与字符串数成比例的工作空间。

    相比下,

    还有很多其他选择,但我认为这些选择可以合理地代表您的选择。 哪一个最适合您的需求取决于您的问题大小的界限,以及您如何权衡空间与速度。 如果您的问题规模可能非常大,并且您无法承担O(n)空间开销,那么请仔细考虑。 如果问题规模确定很小,但空间保护至关重要,那么考虑插入排序。 如果高速是重要的,你可以承担太空间的开销,那么你原来的方法非常有吸引力。

      以上就是c/c++开发分享将未排序的连续字符串数组有效地排序到文件中相关内容,想了解更多C/C++开发(异常处理)及C/C++游戏开发关注计算机技术网(www.ctvol.com)!)。

      本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

      ctvol管理联系方式QQ:251552304

      本文章地址:https://www.ctvol.com/c-cdevelopment/549289.html

      (0)
      上一篇 2021年1月14日
      下一篇 2021年1月14日

      精彩推荐