gpt4 book ai didi

c++ - 什么是 CStringArray 或 CSortStringArray。以及如何按顺序排列这个数组?

转载 作者:搜寻专家 更新时间:2023-10-31 02:22:52 24 4
gpt4 key购买 nike

问题是如果我只使用 CStringArray 而不是 CSortStringArray 如何排列顺序 第一个数组 sortarray 的排列是从 (a 到 m) 的顺序。但是,如果我使用 CSortStringArray,排列仍然相同。第二个数组 sortarray1 从 1.txt 到 15.txt 使用 CStringArrayCSortStringArray 顺序总是错误的?

void CtestmfcDlg::OnBnClickedOk()
{
CSortStringArray sortArray;
sortArray.Add(CString("a"));
sortArray.Add(CString("b"));
sortArray.Add(CString("c"));
sortArray.Add(CString("d"));
sortArray.Add(CString("e"));
sortArray.Add(CString("f"));
sortArray.Add(CString("g"));
sortArray.Add(CString("h"));
sortArray.Add(CString("i"));
sortArray.Add(CString("j"));
sortArray.Add(CString("k"));
sortArray.Add(CString("l"));
sortArray.Add(CString("m"));

CSortStringArray sortArray1;

sortArray1.Add(CString("1.txt"));
sortArray1.Add(CString("2.txt"));
sortArray1.Add(CString("3.txt"));
sortArray1.Add(CString("4.txt"));
sortArray1.Add(CString("5.txt"));
sortArray1.Add(CString("6.txt"));
sortArray1.Add(CString("7.txt"));
sortArray1.Add(CString("8.txt"));
sortArray1.Add(CString("9.txt"));
sortArray1.Add(CString("10.txt"));
sortArray1.Add(CString("11.txt"));
sortArray1.Add(CString("12.txt"));
sortArray1.Add(CString("13.txt"));
sortArray1.Add(CString("14.txt"));
sortArray1.Add(CString("15.txt"));



for (int i = 0; i <= sortArray.GetUpperBound(); i++)
{
testbox1.AddString(sortArray[i]);
}
//sortArray.Sort();

for (int j = 0; j <= sortArray1.GetUpperBound(); j++)
{
testbox2.AddString(sortArray1[j]);
}

}

最佳答案

如果最低系统要求是 Vista 或更高,那么您可以使用 CompareStringEx

#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
#include "windows.h"

using namespace std;

int wmain()
{
vector<wstring> sa;
wchar_t temp[50];
for (int i = 12; i > 0; i--)
{
wsprintf(temp, L"%d.txt", i);
sa.push_back(temp);
}

struct {
bool operator()(const wstring &a, const wstring &b) {
return CompareStringEx(0, SORT_DIGITSASNUMBERS,
a.c_str(), a.length(), b.c_str(), b.length(), 0, 0, 0) == CSTR_LESS_THAN;
}
} mysort;
sort(sa.begin(), sa.end(), mysort);

for (size_t i = 0, count = sa.size(); i < count; i++)
wcout << sa[i] << endl;

return 0;
}

输出:

1.txt
2.txt
3.txt
...
9.txt
10.txt
11.txt
12.txt

关于c++ - 什么是 CStringArray 或 CSortStringArray。以及如何按顺序排列这个数组?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29887972/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com