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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Создать иерархию классов, простейший футбольный турнир http://www.cyberforum.ru/cpp-beginners/thread1033167.html
класс FootballClub - клуб, принимающий участие в турнире: название; город; год основания; рейтинг (целое число от 1 до 5); класс Match - матч в рамках турнира: принимающий и гостевой клубы; итоговый счет; метод для ручного ввода счета;
C++ Не воспринимает проверку #include "stdafx.h" #include "stdio.h" #include "string" #include "conio.h" #define NMAX 4 void vvod(double m, char name) { int i,j,k; double buf=0; http://www.cyberforum.ru/cpp-beginners/thread1033156.html
Программа по указателям C++
Вывести на консоль у виде таблицы значений чисел у десятиричному и 16ричному формате и их адрес у оперативной памяти для типов int, float, double, char, bool, long. Представить те самые числа у виде отдельных байтов и вывести их на консоль.
C++ синтаксис
Только начали изучать С++. До этого писали на Pascal в Lazarus и Delphi. Подскажите, пожалуйста, как правильно задать промежуток в C++, например, '0'..'9'?.
C++ Найти минимальное расстояние от точки до точки http://www.cyberforum.ru/cpp-beginners/thread1033145.html
В последнем цикле, который должен находить минимальное расстояние от точки до точки и его индекс, какая-то ошибка. Немогу её увидеть. Помогите найти пожалуйста.
C++ Шифрование Привет всем:) особенно тем кто в этот день тратит свое время на программирование:) Помогите решить такую задачу. Есть целое число "1234". Его нужно зашифровать. Шифр: заменить каждое число суммой этого числа + 7 % 10 ( 1 + 7 % 10, 2 + 7 % 10 и ... ). Затем первое число поменять местами с третьим, 2 с 4. Я думаю на счет указателей, буду пытаться сам. Но заранее спасибо:) Добавлено через 46... подробнее

Показать сообщение отдельно
Ярославна
0 / 0 / 0
Регистрация: 07.02.2012
Сообщений: 10
08.12.2013, 16:17     Удаление из массива повторяющихся элементов
Это первый пункт задачи:
Используя генератор случайных чисел, заполнить массив из 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 значений>
-вторая часть массива: <оставшиеся значения>
-число удаленных элементов = <значение>
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 03:53. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru