С Новым годом! Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 23.11.2013
Сообщений: 11
1

Динамические массивы как вселенское зло

23.11.2013, 02:20. Показов 1185. Ответов 15
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
У меня задача - вывести повторяющиеся слова и количество повторений, вроде все должно работать, но куда там)
Мне кажется ошибка в работе с памятью динамических массивов(на это указывают ошибки, в которых скащано о несоотвествии считываемой и занятой памяти), но осознать что не так у меня не выходит. Вот код:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
 int nst1,c=0,**c_mass;
 char **ws;
 AnsiString t1,t2;
 nst1 = ComboBox1->ItemIndex;
 String st1 = ComboBox1->Items->Strings[nst1];
 int len=st1.Length();
 if (len<=0) return;
 ws=new char*[len];
 int n;
 c_mass=new int*[n];
 len=n=0;
 int i=2,pos=1,k=0,check=0;
 if (st1[1]!=' ')i=1;
 for (i=1;i<=st1.Length();i++)
 {
  check++;
  k=0;
  pos=i;
  for (i;i<=st1.Length();1)
  {
  if (st1[i]==' ')break;
  i++;
  k++;
  }
  if(st1.SubString(pos,1)!=' ')
  {
        if (check%2!=0)
         {
          t1=st1.SubString(pos,k);
         }
          else
           {
            t2=st1.SubString(pos,k);
           }
            if (t1==t2)
             {
             c++;
             ws[len]=new char[len];
             c_mass[len]=new int[n];
             ws[len]=t1.c_str();
             c_mass[n]=&c;
             len++;
             n++;
             }
  }
 }
 for (i=0;i<=c;i++)
 {
  Memo1->Lines->Add(AnsiString(ws[i])+IntToStr(c_mass[i]));
 }
 delete []ws;
 delete []c_mass;
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
23.11.2013, 02:20
Ответы с готовыми решениями:

Как использовать динамические массивы?
При создании массива количество элементов приписывается заранее. Что делать, если в дальнейшем мне...

Как сделать динамические массивы из статических
Здравствуйте, мне дали задание сгенерировать квадратную матрицу, на промежутке от а до b, и...

Как реализовать динамические массивы из Fortran?
Как можно сконвертировать этот код из Fortran в C++? Пробовал искать, но, к сожалению, попытки не...

Как сделать динамические вложенные массивы?
Всем привет!!! Мне надо реализовать примерно такой код: ... for i:=0 to 4 do begin for...

15
91 / 91 / 22
Регистрация: 02.07.2013
Сообщений: 332
23.11.2013, 11:22 2
Зачем возиться с динамическими указателями на массивы char, если можно запоминать указатель на класс, где есть AnsiString и целое? Это какое-то требование или религия не позволяет?
0
0 / 0 / 0
Регистрация: 23.11.2013
Сообщений: 11
23.11.2013, 19:36  [ТС] 3
Цитата Сообщение от c0rvax Посмотреть сообщение
Зачем возиться с динамическими указателями на массивы char, если можно запоминать указатель на класс, где есть AnsiString и целое? Это какое-то требование или религия не позволяет?
Это незнание) Если не сложно, распиши подробнее.

Добавлено через 7 минут
если под классом вы имеете ввиду структуру(не кидайтесь тапками, в моем понимании класс - int char double и т.д.), то я пытался, но оказалось не так просто
0
91 / 91 / 22
Регистрация: 02.07.2013
Сообщений: 332
23.11.2013, 21:03 4
Хорошо, пусть не класс. Структура, если так понятнее.
Код
typedef struct
{
  AnsiString S;
  int I;
} TMyStruct;

// динамический массив структур
// описали в классе формы, например
class TForm1 : public TForm
{
  ...
  private:
    std::vector<TMyStruct> vArray;
  ...
};

// добавляем в коде функции новый элемент
TMyStruct Item;
Item.S = t1;
Item.I = c; // непонятно, зачем &c
vArray.push_back( Item );
1
0 / 0 / 0
Регистрация: 23.11.2013
Сообщений: 11
23.11.2013, 21:13  [ТС] 5
Цитата Сообщение от c0rvax Посмотреть сообщение
Хорошо, пусть не класс. Структура, если так понятнее.
Код
typedef struct
{
  AnsiString S;
  int I;
} TMyStruct;

// динамический массив структур
// описали в классе формы, например
class TForm1 : public TForm
{
  ...
  private:
    std::vector<TMyStruct> vArray;
  ...
};

// добавляем в коде функции новый элемент
TMyStruct Item;
Item.S = t1;
Item.I = c; // непонятно, зачем &c
vArray.push_back( Item );
&c поставил ибо билдер орал о неприводимости типов int* и int
сейчас попробую, спасибо

Добавлено через 6 минут
что это значит?
C++
1
2
3
4
5
6
{
  ...
  private:
    std::vector<TMyStruct> vArray;
  ...
};
для меня основная проблемма сформировать массив значений структуры. по сути добавление структуры меняет только то, что массив теперь будет 1
0
91 / 91 / 22
Регистрация: 02.07.2013
Сообщений: 332
23.11.2013, 21:29 6
Вектор - это динамический массив. Сколько раз сделаешь vArray.push_back, столько элементов нём и будет. И ничего не надо выделять или уничтожать.
C++
1
2
3
4
5
for ( i=0; i < vArray.size(); i++ )
 {
  TMyStruct Item = vArray[ i ];
  Memo1->Lines->Add( Item.S + IntToStr( Item.I ) );
 }
Так понятнее?
0
2836 / 1645 / 254
Регистрация: 03.12.2007
Сообщений: 4,222
23.11.2013, 21:33 7
Тогда уж сразу std::map...
0
0 / 0 / 0
Регистрация: 23.11.2013
Сообщений: 11
23.11.2013, 21:51  [ТС] 8
Поставлю вопрос иначе:
Как к этому коду прикрутить занесение значений в массив
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
typedef struct
{
  AnsiString S;
  int I;
} OutInf; //структура, в которую нужно заносить значения
 int nst1,c=1;
 AnsiString t1,t2;
 nst1 = ComboBox1->ItemIndex;
 String st1 = ComboBox1->Items->Strings[nst1];
 int i=2,pos=1,k=0,check=0;
 if (st1[1]!=' ')i=1;
 for (i=1;i<=st1.Length();i++)
 {
  check++;
  k=0;
  pos=i;
  for (i;i<=st1.Length();1)
  {
  if (st1[i]==' ')break;
  i++;
  k++;
  }
  if(st1.SubString(pos,1)!=' ')
  {
        if (check%2!=0)
         {
          t1=st1.SubString(pos,k);
         }
          else
           {
            t2=st1.SubString(pos,k);
           }
            if (t1==t2)
             {
             c++;
             // тут нужно заносить значения в массив
             }
  }
 }
  for (i=0;i<=c;i++)
 {
  Memo1->Lines->Add(AnsiString(OutInf.S)+" "+IntToStr(OutInf(I)); // вывод "слово"+"кол-во повторений"
 }
Добавлено через 2 минуты
Цитата Сообщение от c0rvax Посмотреть сообщение
Вектор - это динамический массив. Сколько раз сделаешь vArray.push_back, столько элементов нём и будет. И ничего не надо выделять или уничтожать.
C++
1
2
3
4
5
for ( i=0; i < vArray.size(); i++ )
 {
  TMyStruct Item = vArray[ i ];
  Memo1->Lines->Add( Item.S + IntToStr( Item.I ) );
 }
Так понятнее?
проблема не вывести, проблема записать значения в этот массив. Ввиду того что я первокурсник с кое-какой методичкой я не знаю и половины синтаксиса =/

Добавлено через 14 минут
C++
1
2
3
4
5
6
7
8
__fastcall TForm1::TForm1(TComponent* Owner)
        : TForm(Owner)
{
{
private:
    std::vector<OutInf> OutInfArr;
};
}
такую запись билдер ругает
[C++ Error] Unit1.cpp(20): E2188 Expression syntax
0
91 / 91 / 22
Регистрация: 02.07.2013
Сообщений: 332
23.11.2013, 22:03 9
Пипец...
1) Открываешь form1.h [или как он там у тебя называется]
2) Там, где у тебя описан класс формы, вставляешь вектор [я же сказал выше куда добавить, почему ты тулишь это в конструктор?]
3) Там, где ты написал "тут нужно заносить значения в массив", вставляешь из моего примера код после комментария "добавляем в коде функции новый элемент"
4) Включаем соображалку, ибо становится скучновато...

Добавлено через 5 минут
Проблема не вывести, говоришь? Вот здесь
C++
1
2
3
4
for (i=0;i<=c;i++)
 {
  Memo1->Lines->Add(AnsiString(OutInf.S)+" "+IntToStr(OutInf(I)); // вывод "слово"+"кол-во повторений"
 }
полный бред написан. Что такое OutInf? Зачем одно и то же значение выводить несколько раз? Зачем AnsiString( OutInf.S )? Это и так AnsiString. Что такое OutInf(I)? Полная бредятина....
0
0 / 0 / 0
Регистрация: 23.11.2013
Сообщений: 11
23.11.2013, 22:06  [ТС] 10
Цитата Сообщение от c0rvax Посмотреть сообщение
Пипец...
1) Открываешь form1.h [или как он там у тебя называется]
2) Там, где у тебя описан класс формы, вставляешь вектор [я же сказал выше куда добавить, почему ты тулишь это в конструктор?]
3) Там, где ты написал "тут нужно заносить значения в массив", вставляешь из моего примера код после комментария "добавляем в коде функции новый элемент"
4) Включаем соображалку, ибо становится скучновато...

Добавлено через 5 минут
Проблема не вывести, говоришь? Вот здесь
C++
1
2
3
4
for (i=0;i<=c;i++)
 {
  Memo1->Lines->Add(AnsiString(OutInf.S)+" "+IntToStr(OutInf(I)); // вывод "слово"+"кол-во повторений"
 }
полный бред написан. Что такое OutInf? Зачем одно и то же значение выводить несколько раз? Зачем AnsiString( OutInf.S )? Это и так AnsiString. Что такое OutInf(I)? Полная бредятина....
OutInf- структура
OutInf(I) - не так написал, извини
вывожу одно и то же, т.к. это потом заменить нужно на массив этих самых значений(который я никак не могу сформировать), или я ради прикола цикл написал?
[я же сказал выше куда добавить, почему ты тулишь это в конструктор?]
C++
1
2
3
4
5
6
7
class TForm1 : public TForm
{
  ...
  private:
    std::vector<TMyStruct> vArray;
  ...
};
для меня не очевидно месторасположение этой штуки, вот и написал туда, где оно мне мешать не будет
когда впихал в *.h
[C++ Error] Unit1.h(36): E2316 'vector' is not a member of 'std'
[C++ Error] Unit1.h(36): E2040 Declaration terminated incorrectly
0
91 / 91 / 22
Регистрация: 02.07.2013
Сообщений: 332
23.11.2013, 22:13 11
Чувствую, дело вообще стухнет, поэтому все описания в теле одной функции [т.е., доступа к вектору будет только внутри этой функции]
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
typedef struct
{
  AnsiString S;
  int I;
} OutInf; //структура, в которую нужно заносить значения
std::vector<OutInf> vArray;
 int nst1,c=1;
 AnsiString t1,t2;
 nst1 = ComboBox1->ItemIndex;
 String st1 = ComboBox1->Items->Strings[nst1];
 int i=2,pos=1,k=0,check=0;
 if (st1[1]!=' ')i=1;
 for (i=1;i<=st1.Length();i++)
 {
  check++;
  k=0;
  pos=i;
  for (i;i<=st1.Length();1)
  {
  if (st1[i]==' ')break;
  i++;
  k++;
  }
  if(st1.SubString(pos,1)!=' ')
  {
        if (check%2!=0)
         {
          t1=st1.SubString(pos,k);
         }
          else
           {
            t2=st1.SubString(pos,k);
           }
            if (t1==t2)
             {
             c++;
             // тут нужно заносить значения в массив
             OutInf Item;
             Item.S = t1;
             Item.I = c;
             vArray.push_back( Item );
             }
  }
 }
  for (i=0;i<vArray.size();i++)
 {
  OutInf Item = vArray[ i ];
  Memo1->Lines->Add(Item.S + " " + IntToStr(Item.I); // вывод "слово"+"кол-во повторений"
 }
Добавлено через 1 минуту
Блин, и не забудь ради Бога
C++
1
#include <vector>
а то опять начнётся...
1
0 / 0 / 0
Регистрация: 23.11.2013
Сообщений: 11
23.11.2013, 22:26  [ТС] 12
Цитата Сообщение от c0rvax Посмотреть сообщение
Чувствую, дело вообще стухнет, поэтому все описания в теле одной функции [т.е., доступа к вектору будет только внутри этой функции]
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
typedef struct
{
  AnsiString S;
  int I;
} OutInf; //структура, в которую нужно заносить значения
std::vector<OutInf> vArray;
 int nst1,c=1;
 AnsiString t1,t2;
 nst1 = ComboBox1->ItemIndex;
 String st1 = ComboBox1->Items->Strings[nst1];
 int i=2,pos=1,k=0,check=0;
 if (st1[1]!=' ')i=1;
 for (i=1;i<=st1.Length();i++)
 {
  check++;
  k=0;
  pos=i;
  for (i;i<=st1.Length();1)
  {
  if (st1[i]==' ')break;
  i++;
  k++;
  }
  if(st1.SubString(pos,1)!=' ')
  {
        if (check%2!=0)
         {
          t1=st1.SubString(pos,k);
         }
          else
           {
            t2=st1.SubString(pos,k);
           }
            if (t1==t2)
             {
             c++;
             // тут нужно заносить значения в массив
             OutInf Item;
             Item.S = t1;
             Item.I = c;
             vArray.push_back( Item );
             }
  }
 }
  for (i=0;i<vArray.size();i++)
 {
  OutInf Item = vArray[ i ];
  Memo1->Lines->Add(Item.S + " " + IntToStr(Item.I); // вывод "слово"+"кол-во повторений"
 }
Добавлено через 1 минуту
Блин, и не забудь ради Бога
C++
1
#include <vector>
а то опять начнётся...
спасибо, про существование #include <vector> я не знал даже)

Добавлено через 12 минут
C++
1
2
3
4
5
6
 typedef struct
{
  AnsiString S;
  int I;
} OutInf;
 std::vector<OutInf> OutInfArr;
обязательно глобально объявлять надо, судя по ругне компилятора)
Но выполнять свою функцию программа не стала =(
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
void __fastcall TForm1::ComboBox1Click(TObject *Sender)
{
 int nst1,c=1;
 AnsiString t1,t2,t3="Все слова в стоке одинаковы";
 nst1 = ComboBox1->ItemIndex;
 String st1 = ComboBox1->Items->Strings[nst1];
 int i=2,pos=1,k=0,check=0;
 if (st1[1]!=' ')i=1;
 for (i=1;i<=st1.Length();i++)
 {
  check++;
  k=0;
  pos=i;
  for (i;i<=st1.Length();1)
  {
  if (st1[i]==' ')break;
  i++;
  k++;
  }
  if(st1.SubString(pos,1)!=' ')
  {
        if (check%2!=0)
         {
          t1=st1.SubString(pos,k);
         }
          else
           {
            t2=st1.SubString(pos,k);
           }
         if (t1==t2)
         {
             c++;
             t3=t2;//исключение неправильной работы при всех одинаковых словах в стрке
         }
          else
          {   OutInf Item;
              Item.S = t3;
              Item.I = c;
              OutInfArr.push_back( Item );
          }
  }
 }
 for (i=0;i<=OutInfArr.size();i++)
 {
  OutInf Item = OutInfArr[ i ];
  Memo1->Lines->Add(Item.S + " " + IntToStr(Item.I));
 }
}
0
91 / 91 / 22
Регистрация: 02.07.2013
Сообщений: 332
23.11.2013, 23:35 13
Проработай алгоритм. Реализуй его не сразу весь, а постепенно. Для начала, реализуй выделение всех слов из строки, без всякого анализа.
0
0 / 0 / 0
Регистрация: 23.11.2013
Сообщений: 11
23.11.2013, 23:37  [ТС] 14
Цитата Сообщение от c0rvax Посмотреть сообщение
Проработай алгоритм. Реализуй его не сразу весь, а постепенно. Для начала, реализуй выделение всех слов из строки, без всякого анализа.
вывод всех слов осуществляется если вот это
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
  for (i;i<=st1.Length();1)
  {
  if (st1[i]==' ')break;
  i++;
  k++;
  }
  if(st1.SubString(pos,1)!=' ')
  {
        if (check%2!=0)
         {
          t1=st1.SubString(pos,k);
         }
          else
           {
            t2=st1.SubString(pos,k);
           }
         if (t1==t2)
         {
             c++;
             t3=t2;
         }
          else
          {   OutInf Item;
              Item.S = t3;
              Item.I = c;
              OutInfArr.push_back( Item );
          }
  }
 }
 for (i=0;i<=OutInfArr.size();i++)
 {
  OutInf Item = OutInfArr[ i ];
  Memo1->Lines->Add(Item.S + " " + IntToStr(Item.I));
 }
заменить на это
C++
1
2
3
4
5
6
7
8
9
10
11
  for (i;i<=st1.Length();1)
  {
  if (st1[i]==' ')break;
  i++;
  k++;
  }
  if(st1.SubString(pos,1)!=' ')
  {
          Memo1->Lines->Add(st1.SubString(pos,k));
  }
 }
0
91 / 91 / 22
Регистрация: 02.07.2013
Сообщений: 332
23.11.2013, 23:43 15
Ну и зачем ты каждый раз добавляешь в массив очередное выделенное слово? Выделил слово, проверил, есть ли оно уже в массиве. Если есть, то просто увеличиваешь счётчик этого слова на 1, если нет, то добавляешь слово в массив, счётчик устанавливаешь в 1.
0
0 / 0 / 0
Регистрация: 23.11.2013
Сообщений: 11
24.11.2013, 00:40  [ТС] 16
Цитата Сообщение от c0rvax Посмотреть сообщение
Ну и зачем ты каждый раз добавляешь в массив очередное выделенное слово? Выделил слово, проверил, есть ли оно уже в массиве. Если есть, то просто увеличиваешь счётчик этого слова на 1, если нет, то добавляешь слово в массив, счётчик устанавливаешь в 1.
попробую, уже устал перечитывать этот код(
0
24.11.2013, 00:40
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.11.2013, 00:40
Помогаю со студенческими работами здесь

Динамические массивы и функции. Динамические массивы.
Дана матрица 6х8 целого типа. Создать одномерный массив, содержащий элементы матрицы, кратные...

Динамические массивы. Имя массива как указатель
Заданием с использованием динамических массивов, вводя размер массива с клавиатуры и используя имя...

Динамические массивы. Имя массива как указатель
Написать программу, в соответствии с заданием с использованием динамических массивов, вводя размер...

Как лучше задавать многомерные динамические массивы?
Прошу прощения за глупые вопросы, ибо новичок, но всё же: как лучше задавать многомерные (возьмём...

Как правильно объявлять двухмерные динамические массивы?
Всем привет, и мой, пожалуй, последний вопрос: как правильно объявлять двухмерные динамические...

Массивы необходимо реализовать как несвязанные динамические данные
При написании программы массивы необходимо реализовать как несвязанные динамические данные, причем...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Блоги программистов
Как перейти с Options API на Composition API в Vue.js
BasicMan 06.01.2025
Почему переход на Composition API актуален В мире современной веб-разработки фреймворк Vue. js продолжает эволюционировать, предлагая разработчикам все более совершенные инструменты для создания. . .
Архитектура современных процессоров
inter-admin 06.01.2025
Процессор (центральный процессор, ЦП) является основным вычислительным устройством компьютера, которое выполняет обработку данных и управляет работой всех остальных компонентов системы. Архитектура. . .
История создания реляционной модели баз данных, правила Кодда
Programming 06.01.2025
Предпосылки создания реляционной модели В конце 1960-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
Полезные поделки на Arduino, которые можно сделать самому
raxper 06.01.2025
Arduino как платформа для творчества Arduino представляет собой удивительную платформу для технического творчества, которая открывает безграничные возможности для создания уникальных проектов. Эта. . .
Подборка решений задач на Python
IT_Exp 06.01.2025
Целью данной подборки является предоставление возможности ознакомиться с различными задачами и их решениями на Python, что может быть полезно как для начинающих, так и для опытных программистов. . . .
С чего начать программировать микроконтроллер­­ы
raxper 06.01.2025
Введение в мир микроконтроллеров Микроконтроллеры стали неотъемлемой частью современного мира, окружая нас повсюду: от простых бытовых приборов до сложных промышленных систем. Эти маленькие. . .
Из чего собрать игровой компьютер
inter-admin 06.01.2025
Сборка игрового компьютера требует особого внимания к выбору комплектующих и их совместимости. Правильно собранный игровой ПК не только обеспечивает комфортный геймплей в современных играх, но и. . .
Обновление сайта www.historian.b­y
Reglage 05.01.2025
Обещал подвести итоги 2024 года для сайта. Однако начну с того, что изменилось за неделю. Добавил краткий урок по последовательности действий при анализе вредоносных файлов и значительно улучшил урок. . .
Как использовать GraphQL в C# с HotChocolate
Programming 05.01.2025
GraphQL — это современный подход к разработке API, который позволяет клиентам запрашивать только те данные, которые им необходимы. Это делает взаимодействие с API более гибким и эффективным по. . .
Модель полного двоичного сумматора с помощью логических операций (python)
AlexSky-coder 04.01.2025
def binSum(x:list, y:list): s=^y] p=x and y for i in range(1,len(x)): s. append((x^y)^p) p=(x and y)or(p and (x or y)) return s x=list() y=list()
Это мы не проходили, это нам не задавали...(аси­­­­­­­­­­­­­­хро­н­н­ы­й счётчик с управляющим сигналом задержки).
Hrethgir 04.01.2025
Асинхронный счётчик на сумматорах (шестиразрядный по числу диодов на плате, но наверное разрядов будет больше - восемь или шестнадцать, а диоды на старшие), так как триггеры прошли тестирование и. . .
Руководство по созданию бота для Телеграм на Python
IT_Exp 04.01.2025
Боты для Телеграм представляют собой автоматизированные программы, которые выполняют различные задачи, взаимодействуя с пользователями через интерфейс мессенджера. В данной статье мы рассмотрим,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru