⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sortutils.cpp

📁 压缩软件源码
💻 CPP
字号:
// SortUtils.cpp

#include "StdAfx.h"

#include "SortUtils.h"

static int __cdecl CompareStrings(const void *a1, const void *a2)
{
  const UString &s1 = *(*(*((const UString ***)a1)));
  const UString &s2 = *(*(*((const UString ***)a2)));
  return s1.CompareNoCase(s2);
}

void SortStringsToIndices(const UStringVector &strings, CIntVector &indices)
{
  indices.Clear();
  if (strings.IsEmpty())
    return;
  int numItems = strings.Size();
  CPointerVector pointers;
  pointers.Reserve(numItems);
  indices.Reserve(numItems);
  int i;
  for(i = 0; i < numItems; i++)
    pointers.Add((void *)&strings.CPointerVector::operator[](i));
  void **stringsBase  = (void **)pointers[0];
  qsort(&pointers[0], numItems, sizeof(void *), CompareStrings);
  for(i = 0; i < numItems; i++)
    indices.Add((int)((void **)pointers[i] - stringsBase));
}

void SortStrings(const UStringVector &src, UStringVector &dest)
{
  CIntVector indices;
  SortStringsToIndices(src, indices);
  dest.Clear();
  dest.Reserve(indices.Size());
  for (int i = 0; i < indices.Size(); i++)
    dest.Add(src[indices[i]]);
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -