Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/29: Рейтинг темы: голосов - 29, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 14.12.2016
Сообщений: 32

Уникальные значения в одномерном массиве

23.01.2017, 23:52. Показов 5822. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Создать массив из 25 элементов, (зандовским путем),
записать в него из оригинального массива - только уникальные значения.
Если они отсутствуют - вывести сообщение.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
23.01.2017, 23:52
Ответы с готовыми решениями:

В одномерном массиве значение каждого элемента заменить разностью этого значения и среднего арифметического значения других элементов
В одномерном массиве значение каждого элемента заменить разностью этого значения и среднего арифметического значения других элементов....

Нахождение максимального значения в одномерном массиве
Нахождение максимального значения в одномерном массиве.

Рекурсивная функция для вычисления наибольшего значения в одномерном массиве
для вычисления наибольшего значения в одномерном массиве

11
 Аватар для FreeYourMind
147 / 147 / 104
Регистрация: 13.11.2016
Сообщений: 557
24.01.2017, 01:10
вроде ничего особого.. имея оригинальный массив и условие уникального элемента..
Цитата Сообщение от APEZ Посмотреть сообщение
зандовским путем
это как?

Добавлено через 3 минуты
вот только возникает вопрос в 1. размерности оригинального массива 2. если в оригинальном массиве нету 25 уникальных элементов - чем заполнить оставшиеся элементы
0
0 / 0 / 0
Регистрация: 14.12.2016
Сообщений: 32
24.01.2017, 01:13  [ТС]
Извиняюсь, ошибка в слове.....рандовским путем(srand)
Да со слов вроде бы ничего особого!!!
Можете просветить меня??? КАК НАХОДЯТ УНИКАЛЬНЫЙ А НА ОРИГИНАЛЬНЫЙ(опять запутался) МАССИВ???

Описать целочисленный массив из 25 элементов.
Заполнить его случайными значениями в указанном пользователем диапазоне.
Создать массив из такого же количества элементов.
Записать в него из оригинального массива :

1.только уникальные значения. Если таких нет - вывести сообщение.
- это условие
0
Комп_Оратор)
Эксперт по математике/физике
 Аватар для IGPIGP
9005 / 4706 / 630
Регистрация: 04.12.2011
Сообщений: 14,003
Записей в блоге: 16
24.01.2017, 01:17
Цитата Сообщение от APEZ Посмотреть сообщение
ошибка в слове.....рандовским путем(srand)
Дык это же срандовским путём, имхо. Рандовским это же по-другому ведь.
0
 Аватар для FreeYourMind
147 / 147 / 104
Регистрация: 13.11.2016
Сообщений: 557
24.01.2017, 01:20
Цитата Сообщение от APEZ Посмотреть сообщение
КАК НАХОДЯТ ОРИГИНАЛЬНЫЙ МАССИВ???
оригинальный - он же исходный - он же и заполняется случайными числами.. с ним вы работаете, и из него берете нужные данные, которые в последствии записываются в другой массив.. например так
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <iostream>
#include <cstdlib>
#include <time.h>
using std::cin;
using std::cout;
using std::endl;
int main()
{  
    srand(time(NULL));
    const int n=50;
    int arr[n];
    cout << "array:" << endl;
    for (int i=0; i<n; i++)
    {
        arr[i] = rand()%16-5;
        cout << arr[i] << ' ';
    }
    return 0;
}
0
0 / 0 / 0
Регистрация: 14.12.2016
Сообщений: 32
24.01.2017, 01:21  [ТС]
Кого как научили выражаться...
0
Комп_Оратор)
Эксперт по математике/физике
 Аватар для IGPIGP
9005 / 4706 / 630
Регистрация: 04.12.2011
Сообщений: 14,003
Записей в блоге: 16
24.01.2017, 01:34
Цитата Сообщение от APEZ Посмотреть сообщение
Создать массив из такого же количества элементов.
это хитро зашифрованное число 25, наверное?
Цитата Сообщение от APEZ Посмотреть сообщение
Записать в него из оригинального массива :
1.только уникальные значения.
А если уникальных 20 штук. То есть меньше
такого же количества 25-ти штук
то чем остальные пять заполнять?
Боюсь, что несмотря на срандовское заполнение, условие задачи у Вас таки зандовское.
0
0 / 0 / 0
Регистрация: 14.12.2016
Сообщений: 32
24.01.2017, 01:52  [ТС]
Ok, покажите пожалуйста, как у Вас код получается
0
Комп_Оратор)
Эксперт по математике/физике
 Аватар для IGPIGP
9005 / 4706 / 630
Регистрация: 04.12.2011
Сообщений: 14,003
Записей в блоге: 16
24.01.2017, 02:05
Цитата Сообщение от APEZ Посмотреть сообщение
Ok, покажите пожалуйста, как у Вас код получается
APEZ, в каждой шутке есть доля шутки.
<<чем остальные пять заполнять?>>
это вполне актуально. Остальное просто, но Вы то почему свой код не показали?
Цитата Сообщение от APEZ Посмотреть сообщение
ошибка в слове.
это простительно. Свободное словообразование, вроде
Цитата Сообщение от APEZ Посмотреть сообщение
рандовским
это где-то предельно, но терпимо. А вот отсутствие попытки что-то написать, это хуже.
0
0 / 0 / 0
Регистрация: 14.12.2016
Сообщений: 32
24.01.2017, 02:37  [ТС]
Вот и весь мой код, из-за этого обратился к Вам!!!
Если бы понял смысл задания, я бы не писал сюда!!!

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include<iostream>
#include<time.h>
using namespace std;
void main()
{
    setlocale(LC_ALL, "russian");
    srand(time(NULL));
const int size = 25;
    int array[size];
    for (size_t i = 0; i < size; i++)
    {
        array[i] = rand() % 30;
        cout << " array [" << i << "] = " << array[i] << "\n";
    }
0
 Аватар для FreeYourMind
147 / 147 / 104
Регистрация: 13.11.2016
Сообщений: 557
24.01.2017, 10:33
вобщем то в свете того что вы не сказали ни условия для уникального элемента, ни в общем то что делать если элементов меньше чем места в преобразованном массиве.. вот мой вариант
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
#include <iostream>
#include <cstdlib>
#include <time.h>
using std::cin;
using std::cout;
using std::endl;
int main()
{  
    srand(time(NULL));
    const int n=25;
    int arr[n], arrout[n], count=0;
    cout << "array:" << endl;
    for (int i=0; i<n; i++)
    {
        arr[i] = rand()%41;
        if (!(arr[i]%2))
            count++;
        cout << arr[i] << ' ';
    }
    if (count == 25)
    {
        cout << "new array:" << endl;
        for (int i=0; i<n; i++)
        {
            if (!(arr[i]%2))
                arrout[i] = arr[i];
            else arrout[i] = 0;
            cout << arrout[i] << ' ';
        }
    }
    else 
        cout << "\nimpossible to create new array!" << endl;
    return 0;
}
0
Комп_Оратор)
Эксперт по математике/физике
 Аватар для IGPIGP
9005 / 4706 / 630
Регистрация: 04.12.2011
Сообщений: 14,003
Записей в блоге: 16
24.01.2017, 16:05
Как водится в программировании - посмотрим в обратном порядке:
Цитата Сообщение от APEZ Посмотреть сообщение
Если бы понял смысл задания, я бы не писал сюда!!!
Чтобы понять нужно попробовать это сделать. Или хотя бы представить, что попробовали. Откуда столько восклицательных знаков?
Цитата Сообщение от APEZ Посмотреть сообщение
Вот и весь мой код, из-за этого обратился к Вам!!!
Кода меньше чем восклицательных знаков, опять-таки. Но код есть и это меняет дело.
Почему нет ввода диапазона? Границы диапазона - пара чисел от большего к меньшему, хотя проверить не помешает. Если бы Вы попытались это сделать, то увидели бы, что отсутствие ограничений на диапазон от пользователя и равенство размеров входного и выходного массивов создают ситуацию в которой нельзя отличить уникальные элементы от остального содержимого, если таковых меньше чем размер массива. Таким образом нужно либо создать "динамический массив" нужного размера, что подразумевает счётчик для его длины, либо просто счётчик в комплект к выходному массиву.
APEZ, не понимая такое задание нужно идти к преподавателю, пытаясь выяснить, чего он добивается.

Добавлено через 38 минут
APEZ, если отсортировать то алгоритм может быть быстрее, но разберите хотя бы это.
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
53
#include <iostream>
#include <ctime>   //time() - для получения числа засевающего (случайно инициализирующего) random()
#include <cstdlib> //srand() - засевает рандомайзер длинным целым от которого тот генерит псевдослучайное число, rand() - сам рандомайзер
using namespace std;
const int n=25;
 
bool is_unique_by_index(int * arr, int val_ind){
    for(int i=0; i<n; i++){
        if(i==val_ind)continue;
            if(arr[i]==arr[val_ind])return false;
    }
return true;
}
 
int main(int argc, char* argv[])
{
int left_bound, right_bound;
cout<<"left_bound= ";
cin>>left_bound;
cout<<"right_bound= ";
cin>>right_bound;
if(right_bound==left_bound){
cout<<"right_bound==left_bound ;)";
cout<<endl;
system("pause");
return 0;
}
if(right_bound<left_bound)swap(left_bound, right_bound);
 
int inp[n], outp[n], count_uniq(0);
srand((int)time(0));//сеем рандомайзер
int diap=right_bound-left_bound;
 
for (int i=0; i<n; i++){
inp[i]=left_bound+rand()%(diap+1);
}
cout<<"Having an input array as:\n";
for (int i=0; i<n; i++){
cout<<inp[i]<<' ';
}
 
for (int i=0; i<n; i++){
if(is_unique_by_index(inp, i))outp[count_uniq++]=inp[i];
}
 
cout<<"\nHaving got an output array of "<<count_uniq<<" elements as:\n";
for (int i=0; i<count_uniq; i++){
cout<<outp[i]<<' ';
}
cout<<endl;
system("pause");
return 0;
}
APEZ, а теперь вопрос. Почему не учитесь?
Это небольшой код, но вряд ли кто-то станет далее что-то делать глядя на srandom'ские восклицательные знаки и зандовские условия.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.01.2017, 16:05
Помогаю со студенческими работами здесь

Написать программу с использованием функции нахождения минимального значения элемента в одномерном массиве
Написать программу с использованием функции нахождения минимального значения элемента в одномерном массиве

Найти сумму максимального значения элементов с четными индексами и минимального значения элементов с нечетными индексами в одномерном массиве
дан одномерный массив А.найти мах(a2,a4..)+мин(a1,a3) int main() { int y; cin&gt;&gt;N; for(int i=0; i&lt;N; i++) cin&gt;&gt;y; max=y;...

Определить уникальные значения в массиве и их количество
Помогите закончить код,вывожу уникальные элементы,все получается,но что дописать,чтобы выводилось и их количество.Заранее спасибо...:wall: ...

Посчитать уникальные значения в двумерном массиве, при условии, что данные связаны
Всем Добрый день. Есть двумерный массив (296, 5), в столбцах с 0 по 2 существует 74 уникальных значения, но каждое уникальное значение...

Уникальные значения столбца А по сравнению со столбцом С и уникальные значения в столбце С по сравнению с А?
Ребята всем привет, как реализовать макросом? Есть два столбца А и С в каждом списки наименований.Как вывести в столбцы F и H(либо на...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru