标题:qsort无法给string类中的字符排序吗?
只看楼主
love24114
Rank: 5Rank: 5
等 级:职业侠客
威 望:1
帖 子:223
专家分:399
注 册:2011-7-11
结帖率:81.48%
已结贴  问题点数:20 回复次数:2 
qsort无法给string类中的字符排序吗?
#include <iostream>
#include <string>
#include <cstdlib>
using namespace std;

int maxcmp(const void *a,const void *b)
{
    printf("OK");
    return *(char *)a-*(char *)b;
}

int main()
{
    string a;
    int n,i,len,sum;
    cin>>n;
    while (n--)
    {
        sum=0;
        cin>>a;
        len=a.size();
        qsort(&a,len,sizeof(a[0]),maxcmp);
        cout<<a;
    }
    return 0;
}
搜索更多相关主题的帖子: return include void 
2012-01-08 12:55
lz1091914999
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:四川
等 级:贵宾
威 望:37
帖 子:2011
专家分:5959
注 册:2010-11-1
得分:10 
程序代码:
#include <iostream>
#include <string>
#include <cstring>
#include <cstdlib>
using namespace std;

int cmp(const void* cp1, const void* cp2) {
   return *(char*)cp1 - *(char*)cp2;
}

int main() {
   string str;
   char* temp;
   int n;

   cin >> n;
   while (n--) {
      cin >> str;
      temp = new char[str.size() + 1];
      strcpy(temp, str.c_str());
      qsort(temp, str.size(), sizeof (char), cmp);
      str = temp;
      cout << str << endl;
      delete temp;
   }
}
似乎只能用这个方法了,何不直接用char[]?这样似乎还更有效。

My life is brilliant
2012-01-09 23:55
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:10 
qsort(&a,len,sizeof(a[0]),maxcmp);
改为
qsort(&a[0],len,sizeof(a[0]),maxcmp);
试试看
我没试
2012-01-10 08:15



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-359346-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.085205 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved