字符串中的随机字母c ++

时间:2016-11-27 00:55:46

标签: c++ string random shuffle

我打算写一个函数来保持字符串的第一个和最后一个字母相同,并忽略最后一个字母后面的任何非字母。我应该使用std :: random_shuffle()。我阅读了文档但是我似乎没有掌握这个功能的概念。这是我的代码:

#include <iostream>
#include <algorithm>
#include <string>

std::string mix(std::string s){
    int last_char;
    if(std::isalpha(s[s.size()-1]) == true){
        last_char = s.size()-1;
    } else {
     for(int i=s.size()-1 ; i>0; --i){
        if((std::isalpha(s[i]) == false) && (std::isalpha(s[i-1])==true)){
            last_char = i -1;
            break;
        }
      }
    }
    std::random_shuffle(&s[1],&s[last_char]);
    return s;

}

int main(){
    std::string test = "Hello";
    std::cout << mix(test) << std::endl;
}

编辑:现在我不断收到错误:分段错误(核心转储)。有人知道为什么?似乎无法找到问题。

3 个答案:

答案 0 :(得分:3)

std::random_shuffle将迭代器或指针作为参数,而不是要排序的数组/容器中的值。您对std::random_shuffle的致电应该是:

std::random_shuffle(&s[1],&s[last_char]);

请注意,第二个参数是结束迭代器值。结束迭代器不指向要排序的最后一个值,而是指向它之后的那个值。

这不是显示代码的唯一问题。您需要在调用std::random_shuffle之前修复代码中的多个错误。例如:

 for(int i=s.size() ; i>0; --i){
    if((std::isalpha(s[i]) == false) && (std::isalpha(s[i-1])==true)){

s.size()为您提供字符串的大小。在第一次迭代中,i将等于其size(),但访问s[i]现在将导致未定义的行为和错误,因为s[i]显然不存在。在包含n个字符的字符串中,字符当然是s[0]s[n-1]

您需要修改算法,以便last_char最终成为 之后的下一个字符的索引 您想要随机播放的那个,然后使用上面的固定std::random_shuffle来电。

或者,或者,将last_char计算为要排序的最后一个字符的索引,然后调用

std::random_shuffle(&s[1],&s[last_char+1]);

两种方法都没问题。

答案 1 :(得分:1)

  1. 您需要在字符串的右侧找到最左边的“非字母”。

  2. 左边的一个地方是最后一个字母的位置。

  3. 右边的一个地方是你的第一封信。

  4. 只需使用“first”和“last”调用random_shuffle。

  5. 以下是一些有用的链接:

    http://www.cplusplus.com/reference/algorithm/random_shuffle/

    请记住,“开始”是包容性的,“结束”是独占的“

答案 2 :(得分:-1)

让你入门的东西。它至少有一个你需要解决的角落案例。访问cppreference.com以了解算法的工作原理。

#include <iostream>
#include <cctype>
#include <algorithm>
#include <string>

std::string
special_shuffle(std::string s)
{
  if (s.size() < 3) return s;
  auto begin = std::find_if(s.begin(), s.end(), ::isalpha);
  auto end = std::find_if(s.rbegin(), s.rend(), ::isalpha).base();
  std::random_shuffle(++begin, --end);
  return s;
}

int
main()
{
  std::string s1 = "Hello World!";
  std::string s2 = "AB";
  std::string s3 = "A";
  std::string s4 = "";
  std::string s5 = "a string going from a to z";

  std::cout << s1 << " --> " << special_shuffle(s1) << "\n"
            << s2 << " --> " << special_shuffle(s2) << "\n"
            << s3 << " --> " << special_shuffle(s3) << "\n"
            << s4 << " --> " << special_shuffle(s4) << "\n"
            << s5 << " --> " << special_shuffle(s5) << "\n";
}

编译并运行:

$ g++ example.cpp -std=c++14 -Wall -Wextra
$ ./a.out
Hello World! --> Hooll eWlrd!
AB --> AB
A --> A
 --> 
a string going from a to z --> aarfritomgi  nnso t  g goz