Возникли проблемы с массивами

0

Я на 100% уверен, что мой код неправильно определяет размер массива. Когда я положил привет в качестве ввода и установил strArray [5], он работает правильно. Но проблема в том, что я не знаю, насколько велика величина ввода, поэтому я просто поставлю 80 (так как это может быть максимум)

Вот мой код.

#include <iostream>
#include <string>
#include <algorithm>
#include <vector>
using namespace std;

main()
{
string str1;
char strArray[80];


cout << "Enter string: ";
getline(cin, str1);

transform(str1.begin(), str1.end(), str1.begin(), ::tolower);
str1.erase(remove(str1.begin(),str1.end(),' '),str1.end());

for(int i = 0;i < str1.length(); i++)
{
        if(str1[i] == ',' || str1[i] == '.')
        {
            str1.erase(i,1);
        }
}

for(int i=0;i<str1.length();i++)
{
        strArray[i] = str1[i];
}

char tempChar;

for(int i = 0; i < (sizeof(strArray)/sizeof(*strArray))-1; i++)
{
    for(int j = 0; j < (sizeof(strArray)/sizeof(*strArray)-1); j++)
    {
        if(strArray[j+1] < strArray[j])
        {
            tempChar = strArray[j];
            strArray[j] = strArray[j+1];
            strArray[j+1] = tempChar;
        }
    }
}

cout << strArray << endl;
return 0;
}
  • 0
    Просто используйте строку, а не таблицу символов
  • 0
    Что вы пытаетесь сделать в этом цикле?
Показать ещё 2 комментария
Теги:

1 ответ

3
Лучший ответ

Вы можете просто создать strArray строку. Или, если вы должны использовать массив char, вы должны динамически выделять массив char *strArray = new char[str1.length()] с помощью char *strArray = new char[str1.length()]. В этом случае не забудьте delete [] strArray; когда сделано.

  • 0
    Смотрите также: unique_ptr и shared_ptr .
  • 0
    Это сработало! Спасибо!

Ещё вопросы

Сообщество Overcoder
Наверх
Меню