Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
3 / 3 / 4
Регистрация: 03.11.2015
Сообщений: 89
1

Все повторяющиеся элементы переставить в самое начало

05.01.2017, 07:49. Показов 1146. Ответов 25
Метки нет (Все метки)

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
int main()
{
    setlocale(LC_ALL,"Russian");
    const int k = 5;
    int A[k];
    int r = 0;
 
    for(int i = 1;i <= k;i++)
    {
        A[i] = rand() % 5;
        cout<<"\t\A["<<i<<"]="<<A[i]<<endl;
    }
for(int i = 1;i <= k;i++)
        for(int j = 1;j <= k;j++)
        {
           if( i != j )//чтобы не было A[2] == A[2]
           {
            if( A[i] == A[j] )//условие
            {
                  r++;//чтобы переставлять попорядку
            int temp = A[r];//сама перестановка
                A[r] = A[i];
                A[i] = temp;
            }
           }
        }
 
     for(int i = 1;i <= k;i++)
    {
        cout<<"C["<<i<<"]="<<A[i]<<endl;//вывод
    }
 
    _getch();
    return 0;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
05.01.2017, 07:49
Ответы с готовыми решениями:

Переставить все отрицательные элементы в начало массива
Здравствуйте, помогите пожалуйста решить такую задачку! Пусть A - одномерный массив N...

Позиционирование в потоке, переставить все нулевые элементы в начало файла
создать функцию, которая с использованием функций позиционирования в потоке переставляет все...

Одномерный массив. Переставить все повторяющиеся элементы в начало
помогите плиз переставить в одномерном массиве все повторяющиеся элементы в начало.

Переставить все максимальные элементы списка в его конец, все минимальные в начало
помогите плз написать программу Переставить все максимальные элементы списка в его конец ,все...

25
3 / 3 / 4
Регистрация: 03.11.2015
Сообщений: 89
07.01.2017, 00:42  [ТС] 21
Author24 — интернет-сервис помощи студентам
Цитата Сообщение от JIawliet Посмотреть сообщение
if (cnt)
можете пожалуйста объяснить,как используется здесь "cnt".
Цитата Сообщение от JIawliet Посмотреть сообщение
result[begCnt++]
получается то,что этот массив не будет начинаться с индекса 0
Цитата Сообщение от JIawliet Посмотреть сообщение
j += --cnt;
как вы изменяете значение j в цикле for?
Цитата Сообщение от JIawliet Посмотреть сообщение
std::sort(std::begin(A), std::end(A));
по вашим объяснениям я понял,что это вложенная уже сортировка(т.е как функция,её уже кто-то написал,а мы используем,чтобы не прописывать много кода)
Суть такая:вы повторяющиеся элементы загоняете сначала,а если не повторяется,то в конец.

Моя программа проверяет и сразу переставляет.Вы сказали логика не правильная,но понимаете это такое понятие обобщенное и мне бы хотелось узнать,в каких именно случаях нельзя её применить или может быть её действия не совместимы с масивами или еще чем-то?
Очень бы хотелось узнать,что не так и может постараться устранить неполадки.
0
90 / 88 / 33
Регистрация: 20.07.2016
Сообщений: 403
07.01.2017, 00:58 22
Цитата Сообщение от Valuamba Посмотреть сообщение
можете пожалуйста объяснить,как используется здесь "cnt".
cnt проверяется на ноль

Цитата Сообщение от Valuamba Посмотреть сообщение
получается то,что этот массив не будет начинаться с индекса 0
все массивы начинаются с нулевого индекса... begCnt изначально 0... операция begCnt++ вернет 0, при этом увеличив begCnt на 1, то есть оператор постфиксного инкремента вернет 0, но сама переменная увеличиться на единицу...

Цитата Сообщение от Valuamba Посмотреть сообщение
как вы изменяете значение j в цикле for?
увеличиваю его на количество повторяющихся элементов, количество которых подсчитано в cnt

Цитата Сообщение от Valuamba Посмотреть сообщение
о вашим объяснениям я понял,что это вложенная уже сортировка(т.е как функция,её уже кто-то написал,а мы используем,чтобы не прописывать много кода)
да, абсолютно верно... + она эффективная, чтоб такую написать необходимо n-ое количество времени и довольно глубокое в вопросе сортировки...

Цитата Сообщение от Valuamba Посмотреть сообщение
Моя программа проверяет и сразу переставляет.
Цитата Сообщение от Valuamba Посмотреть сообщение
Очень бы хотелось узнать,что не так и может постараться устранить неполадки.
вам необходимо проверить свой алгоритм на листочке при чем несколько раз с различными данными, тогда вы поймете, что просто так эту задачу не решить и там есть определенные нюансы
1
3 / 3 / 4
Регистрация: 03.11.2015
Сообщений: 89
07.01.2017, 01:38  [ТС] 23
Цитата Сообщение от JIawliet Посмотреть сообщение
Сообщение от Valuamba
как вы изменяете значение j в цикле for?
увеличиваю его на количество повторяющихся элементов, количество которых подсчитано в cnt
мне казалось,что значение переменной,используемой в цикле,нельзя изменять.
0
Модератор
Эксперт CЭксперт С++
5284 / 2371 / 342
Регистрация: 20.02.2013
Сообщений: 5,770
Записей в блоге: 20
07.01.2017, 01:40 24
Цитата Сообщение от Valuamba Посмотреть сообщение
нельзя
"Нельзя" в смысле "невозможно"? Или "нельзя" в смысле "не безопасно"?
0
3 / 3 / 4
Регистрация: 03.11.2015
Сообщений: 89
07.01.2017, 10:43  [ТС] 25
В смысле "невозможно".Помню мне вечно выбивал компилятор ошибку
0
Модератор
Эксперт CЭксперт С++
5284 / 2371 / 342
Регистрация: 20.02.2013
Сообщений: 5,770
Записей в блоге: 20
07.01.2017, 11:21 26
Valuamba, если переменная не имеет квалификатора const, то её значение можно изменять.
0
07.01.2017, 11:21
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
07.01.2017, 11:21
Помогаю со студенческими работами здесь

Переставить в начало массива все положительные элементы
Сформировать одномерный массив из 20 случайных чисел (положительных и отрицательных), и переставить...

Переставить в массиве все отрицательные элементы в начало массива, сохраняя относительный порядок
Проштудировал весь форум.Решений много взял по примеру написал код, ошибок нет но ответа нужного...

Найти все минимальные и максимальные элементы и переставить их в начало и конец списка соответственно
Помогите пожалуйста решить задачку. Задан список, нужно найти все минимальные и максимальные...

Дана матрица.Заменить все повторяющиеся элементы - 1, а не повторяющиеся - 0
Дана матрица. Заменить все повторяющиеся элементы - 1, а не повторяющиеся - 0. Как мне заменить?...


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

Или воспользуйтесь поиском по форуму:
26
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru