Форум программистов, компьютерный форум CyberForum.ru

Удаление из массива повторяющихся элементов - C++

Восстановить пароль Регистрация
 
Ярославна
0 / 0 / 0
Регистрация: 07.02.2012
Сообщений: 10
08.12.2013, 16:17     Удаление из массива повторяющихся элементов #1
Это первый пункт задачи:
Используя генератор случайных чисел, заполнить массив из 20 элементов целочисленными значениями в диапазоне [11, 39], сумма цифр которых меньше 7.
Прототип пользовательской функции:
int genprint(int*, const int, const int, const int);
параметры функции: массив, число элементов массива, левая и правая границы интервала случайных чисел, верхняя граница суммы чисел. Функция возвращает общее число сгенерированных значений, которое потребовалось для заполнения всего массива числами.

*) вывод получаемых значений происходит в функции main(); значения элементов массива выводятся в две строки по 10 элементов в каждой в след виде:
- первые 10 элементов: <значения>
- вторые 10 элементов: <значения>
(выводимые значения аккуратно выравниваются; ширина поля вывода равняется 4).
- число сгенерированных значений = <значение>

Решение:
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
#include "stdafx.h"
#include <iostream>
#include <cstdlib>
#include <ctime>
#include <iomanip>
using namespace std;
 
int genprint(int *, const int, const int, const int, const int);
 
int main()
{
    setlocale(LC_ALL, "Russian");
    srand(time(0));
 
    const int arrSize = 20;
    int massiv[arrSize];
    int left = 11, right = 39, high = 7;
    int chislo;
    chislo = genprint(massiv, arrSize, left, right, high);
 
    cout<<"Вывод нашего массива: \n";
    cout<<"Первые десять значений: ";
    for(int i=0; i<(arrSize/2); i++)
        cout<<setw(4)<<massiv[i];
        cout<<'\n';
    cout<<"Вторые десять значений: ";
    for(int i=arrSize/2; i<arrSize; i++)
        cout<<setw(4)<<massiv[i];
        cout<<'\n'<<"число сгенерированных значений = <"<<chislo<<"> \n";
    system("pause");
    return 0;
}
 
int genprint(int *arr, const int N, const int lb, const int rb, const int hb)
{
    int a;
    int i = 0, counter = 0;
    while(i<N)
    {
        a=rand()%(rb-lb+1)+lb;
        counter++;
        if((a%10)+(a/10)<7)
        {
            arr[i] = a;
            i++;
        }
    }
    return counter;
}
Как решить второй пункт?
Второй пункт задачи:
Удалить из массива все повторяющиеся элементы, оставив только их первые вхождения(исключая элемент массива, все следующие за ним элементы смещаются влево на 1 позицию; последний элемент массива получает значение 0).
Прототип пользовательской функции:
int delem(int*, const int);
Функция возвращает число удаленных элементов.

*) результат выводится в функции main() без нулевых значений, но с указанием числа удаленных элементов:
-первая часть массива: <не более 10 значений>
-вторая часть массива: <оставшиеся значения>
-число удаленных элементов = <значение>
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.12.2013, 16:17     Удаление из массива повторяющихся элементов
Посмотрите здесь:

удаление из массива повторяющихся элементов! где-то маленькая ошибка! C++
C++ Удаление повторяющихся элементов из списка
C++ Удаление из строки повторяющихся элементов (через функцию)
C++ Удаление повторяющихся символов массива
C++ Сохранение строки в массив и удаление повторяющихся элементов массива
Удаление повторяющихся элементов в векторе C++
Удаление из вектора повторяющихся элементов C++
Удаление повторяющихся элементов в односвязном списке C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 21:03. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru