| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 823 人关注过本帖
标题: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
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:10 
qsort(&a,len,sizeof(a[0]),maxcmp);
改为
qsort(&a[0],len,sizeof(a[0]),maxcmp);
试试看
我没试
2012-01-10 08:15
快速回复:qsort无法给string类中的字符排序吗?
数据加载中...
 
   



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

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