Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
aus
7 / 7 / 1
Регистрация: 18.10.2010
Сообщений: 56
#1

Найти в массиве подряд идущие элементы - C++

18.10.2010, 14:06. Просмотров 1120. Ответов 12
Метки нет (Все метки)

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
//---------------------------------------------------------------------------
 
#include <vcl.h>
#pragma hdrstop
#include <iostream.h>
#include <conio.h>
#include <stdio.h>
//---------------------------------------------------------------------------
 
#pragma argsused
int main(int argc, char* argv[])
{       int n; int S=0;
        int *parr;
        cout<<"Vvedite razmer massiva:";
        cin>>n;
        parr=new int[n];
        for (int i=0;i<n;i++)
        {
        cout<<"\nVvedite element massiva:";
        cin>>parr[n];
        }
        for (int i=0;i<n;i++)
        {
        if (parr[n]==parr[n+1]) S++;
        }
        cout<<S;
        delete [n] parr;
        getch();
        return 0;
}
//---------------------------------------------------------------------------

Надо найти подряд идущие одинаковые элементы. В чем здесь ошибка?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.10.2010, 14:06
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Найти в массиве подряд идущие элементы (C++):

Исключить все повторяющиеся, идущие подряд элементы дека - C++
Создать список из целых чисел. Подсчитать количество пар соседних элементов, которые совпадают между собой. Оставить по одному из таких...

В массиве A=(a1, а2, ., an) удалить все положительные элементы, имеющие четный порядковый номер, идущие после минимального элемента массива - C++
В массиве A=(a1, а2, ..., an) удалить все положительные элементы, имеющие четный порядковый номер, идущие после минимального элемента...

Идущие подряд числа - C++
Есть код, суть его в возведении числа в степень (ооочень большую степень - 3^3456), в результате тоже как бы число (массив), нужно...

Заменить 2 подряд идущие буквы на 1 символ - C++
Заменить 2 подряд идущие буквы на 1 символ У меня вышло как то так но не получается доработать. #include &lt;iostream&gt; #include...

Удалить подряд идущие вхождения слова в предложениях - C++
Дана строка содержащая текст на русском языке. В предложении некоторые слова записаны подряд несколько раз.Заканчивается предложение...

Заменить подряд идущие пробелы на один пробел - C++
2) В заданной строке заменить подряд идущие пробелы на один пробел (посредством цикла for).

12
mamedovvms
2918 / 839 / 93
Регистрация: 30.04.2009
Сообщений: 2,633
18.10.2010, 14:11 #2
Цитата Сообщение от aus Посмотреть сообщение
Надо найти подряд идущие одинаковые элементы. В чем здесь ошибка?
может быть нужно найти самую длинную последовательность одинаковых подряд идущих элементов?

Добавлено через 1 минуту
во вторых в цикле поиска равных нужно делать i<n-1 так как у вас идет сравнение с последующим, а с чем вы будете сравнивать последний элемент, значит нужно последним сравнивать предпоследний элемент
1
aus
7 / 7 / 1
Регистрация: 18.10.2010
Сообщений: 56
18.10.2010, 14:11  [ТС] #3
Да самую длинную
0
Nevecap
12 / 12 / 1
Регистрация: 18.10.2010
Сообщений: 59
18.10.2010, 14:15 #4
C++
1
if (parr[n]==parr[n+1]) S++;
Я так понимаю, в виду имелось
C++
1
if (parr[i]==parr[i+1]) S++;
?)
C++
1
cin>>parr[n];
И здесь тоже...
1
mamedovvms
2918 / 839 / 93
Регистрация: 30.04.2009
Сообщений: 2,633
18.10.2010, 14:18 #5
вот этот цикл
C++
1
2
3
4
for (int i=0;i<n;i++)
        {
        if (parr[n]==parr[n+1]) S++;
        }
Замените на это
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
s=1;
 int tempS=1;
int index =0;
for (int i=0;i<n-1;i++){
 if (a[i]==a[i+1]){
  tempS++;
 }
 else{
  if (tempS>s){s=tempS; index=i-s;}
  tempS=1;
 }
}
//Вывод последовательности
for (int i=index; i<index+s;i++){
 cout<<a[i]<<" ";
}
1
aus
7 / 7 / 1
Регистрация: 18.10.2010
Сообщений: 56
18.10.2010, 14:24  [ТС] #6
Спасиб всем.
И еще он на выделение памяти ошибку выдает
0
mamedovvms
2918 / 839 / 93
Регистрация: 30.04.2009
Сообщений: 2,633
18.10.2010, 14:29 #7
где выдает?
0
aus
7 / 7 / 1
Регистрация: 18.10.2010
Сообщений: 56
18.10.2010, 14:35  [ТС] #8
На освобождении памяти
0
ForEveR
В астрале
Эксперт С++
7988 / 4747 / 321
Регистрация: 24.06.2010
Сообщений: 10,547
Завершенные тесты: 3
18.10.2010, 14:40 #9
aus, Угу. Потому что просто delete[] parr;
1
Shman
3 / 3 / 2
Регистрация: 30.04.2012
Сообщений: 212
25.05.2012, 17:34 #10
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
#include <stdio.h> // Подключаем
#include <conio.h> // модули.
 
int main()
{     
 int mass[5]; // Обявляем массив.
 int i, n, s, tempS, index; // Переменные.
 
 printf("Vvedite massiv iz 5 elementov \n:"); 
 
  for (i=0; i<5; i++) // Счетчик.
   { printf("Vvedite element[%d]: ", i); // Введите очередной элемент массива.
     scanf("%d", &mass[i]); } // Запомнить ввод.
 
 s=1;
 tempS=1;
 index=0;
  for (i=0; i<i-1; i++){
   if (mass[i]==mass[i+1])
    { tempS++; }
   else
    {
      if (tempS>s)
      { s=tempS; 
        index=i-s; }
     tempS=1;
    }
   
  for (i=index; i<index+s; i++)  
  {
    printf ("\n Result: %d ", mass[i]); // Вывести результат. 
  }
 getch(); 
 return 0;
}
}
ГДЕ ОШИБКА скажите пжста?
0
Nevecap
12 / 12 / 1
Регистрация: 18.10.2010
Сообщений: 59
25.05.2012, 23:41 #11
Цитата Сообщение от Shman Посмотреть сообщение
[CPP]
ГДЕ ОШИБКА скажите пжста?
Во-первых, в цикле
C
1
for (i=0; i<i-1; i++)
условие i < i-1 всегда ложно.
UPD Блин, старая версия прогрузилась...
UPD2 А, не, уже исправлено просто, трудный день был, не сразу понял)
0
MrGluck
Модератор
Эксперт CЭксперт С++
7524 / 4662 / 704
Регистрация: 29.11.2010
Сообщений: 12,733
26.05.2012, 03:36 #12
Цитата Сообщение от Shman Посмотреть сообщение
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
#include <stdio.h> // Подключаем
#include <conio.h> // модули.
 
int main()
{     
 int mass[5]; // Обявляем массив.
 int i, n, s, tempS, index; // Переменные.
 
 printf("Vvedite massiv iz 5 elementov \n:"); 
 
  for (i=0; i<5; i++) // Счетчик.
   { printf("Vvedite element[%d]: ", i); // Введите очередной элемент массива.
     scanf("%d", &mass[i]); } // Запомнить ввод.
 
 s=1;
 tempS=1;
 index=0;
  for (i=0; i<i-1; i++){
   if (mass[i]==mass[i+1])
    { tempS++; }
   else
    {
      if (tempS>s)
      { s=tempS; 
        index=i-s; }
     tempS=1;
    }
   
  for (i=index; i<index+s; i++)  
  {
    printf ("\n Result: %d ", mass[i]); // Вывести результат. 
  }
 getch(); 
 return 0;
}
}
ГДЕ ОШИБКА скажите пжста?
в этом интересном условии цикла
C++
1
for (i=0; i<i-1; i++){
Один вопрос, почему vcl.h ?
0
Shman
3 / 3 / 2
Регистрация: 30.04.2012
Сообщений: 212
26.05.2012, 06:18 #13
Nevecap,
MrGluck,
В этом интересном условии цикла
А как правильно?
0
26.05.2012, 06:18
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
26.05.2012, 06:18
Привет! Вот еще темы с ответами:

Удалить одинаковые слова предложения, идущие подряд - C++
Объясните как это сделать с помощью библиотеки &lt;string.h&gt; Удалить одинаковые слова предложения, идущие подряд.

Удалить подряд идущие одинаковые слова из строки - C++
Одна из ошибок, которую часто допускают неопытные наборщики - дважды написанное слово. Найти такие ошибки в заданном тексте и исправить их ...

В файле суммировать подряд идущие значения одного знака - C++
Пусть дан файл целых чисел. Создайте новый файл, значения в который записываются по следующему правилу: суммируются подряд идущие...

Заменить в строке подряд идущие две буквы на одну - C++
Заменить в строке S подряд идущие буквы «а» на одну букву «а». помогите с кодом.не могу разобратся int _tmain(int argc, _TCHAR* argv) ...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru