如何对字符串数组的每个字符串进行排序

sau*_*wal 2 c++ sorting string

我想排序每个字符串数组的字符串,这是我尝试的代码.

#include <iostream>
#include <algorithm>

void _sort_word(char *str)
{
    int len = strlen(str); 
    std::sort(str,str+len); // program get stuck here. 
}
int main()
{
    char *str[] = {"hello", "world"};
    for(int i=0;i<2;i++){
        _sort_word(str[i]);
        cout << str[i] << "\n";
    }
}
Run Code Online (Sandbox Code Playgroud)

我想知道sort(str,str+len);这里有一个有效的陈述,如果不是应该做什么呢?

Vla*_*cow 6

首先,C++中的字符串文字具有常量字符数组的类型.所以正确的数组声明看起来像

const char *str[] = {"hello", "world"};
^^^^^
Run Code Online (Sandbox Code Playgroud)

因此,数组元素指向的字符串文字是不可变的.

你应该声明至少一个二维数组.

这是一个示范计划

#include <iostream>
#include <algorithm>
#include <cstring>

void sort_word( char *s )
{
    size_t l = std::strlen( s ); 
    std::sort( s, s + l ); 
}


int main() 
{
    char str[][6] = { "hello", "world" };

    for ( auto &s : str ) sort_word( s );
    for ( auto &s : str ) std::cout << s << std::endl;

    return 0;
}
Run Code Online (Sandbox Code Playgroud)

它的输出是

ehllo
dlorw
Run Code Online (Sandbox Code Playgroud)

如果您的编译器不支持基于for语句的范围,那么您可以改为编写

for ( size_t i = 0; i < sizeof( str ) / sizeof( *str ); i++ ) sort_word( str[i] );
Run Code Online (Sandbox Code Playgroud)