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

В заданном массиве найти максимальный элемент среди уникальных; если такового нет, вывести сообщение об этом

02.10.2018, 19:04. Показов 3466. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите закончить программу
Условие:
Задан масив целых чисел a(n), n<=400. Написать программу, которая находит максимальное среди тех чисел, которые не повторяются. Если таких чисел нет, то выводит сообщение об этом.
Мой код, немогу дописать никак


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
#include <iostream>
#include <stdlib.h>
#include <time.h>
using namespace std;
int main() {
    srand(time(NULL));
    long n,i;
    bool temp = true;
    do {
        cout<< "Input arrange" <<endl;}
    while (cin >> n && (n < 0 || n > 400));
 
 
    int arr[n];
    for ( i = 0; i < n; i++) {
        arr [i] = rand()%20-10;
        cout << arr[i]<<" ";
    }
    cout << endl;
 
    int max = arr[0];
    for (int i = 1; i < n; i++) {
        if (arr[i] > max) {
            max = arr[i];
        }
    }
 
 
    for ( int i = 0; i < n; i++) {
        for ( int j = 0; j < n; j++) {
        if ( arr[i] == arr[j] && i !=j )
        {
        temp = false;
        break;
        }
        }
    if ( temp ) cout << " " << arr[i]<<endl;
    temp = true;
 
    }
   
 
 
    return 0;
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
02.10.2018, 19:04
Ответы с готовыми решениями:

Дан массив целых чисел. Найти В этом массиве минимальный элемент т и максимальный элемент м. Вывести сумму элементов от минимального до максимального
Дан массив целых чисел. Найти В этом массиве минимальный элемент т и максимальный элемент м. Вывести сумму элементов от минимального до...

Найти минимальное положительное число в заданном массиве, а если таких нет, вывести на экран ноль
Дан одномерный массив А. Найти минимальное положительное число из данного массива. Если положительные числа в наборе отсутствуют, то...

Найти нужный элемент в массиве и вывести его индекс, если такого нет, то вывести -1
Нужно найти нужный элемент в массиве и вывести его индекс, если такого нету, то вывести -1. Написал тут код, в чем проблема? ...

1
26 / 23 / 12
Регистрация: 25.06.2018
Сообщений: 91
02.10.2018, 23:59
Лучший ответ Сообщение было отмечено SantaLucia22 как решение

Решение

Слишком сложно. После ввода значений проведи сортировку с уменьшением значения. А дальше сравниваешь. Если значения не равны, то это есть максимальное неповторяющееся и выходишь из поиска. Если равны, то пропускаешь все эти значения. Так работаешь до тех пор пока не закончится массив.
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
// есть список int arr[] и количество значений
int cmp(const void *a,const void *b) {
    return ((const int)a < ((const int)b);
}
void sort(int * arr, int count)
{
   qsort(arr, count, sizeof(int), cmp);
}
int find(int* arr, int count, bool* found)
{
   int k = 0;
   sort(arr, count);
   *found = false; // по умолчанию считаем, что значение не найдено
   while(k < count)
   {
      if(k + 1 >= count) 
      {
         return 0;  // максимальное неповторяющееся значение не найдено
      }
      if(arr[k] != arr[k+1])
      {
          *found =  true;  // значение найдено
          return arr[k];
      }
      // пропускаем повторяющиеся значения. k увеличивается на 2, так как у нас уже 2 проверенных значения. 
      int tmp = arr[k];
      k += 2;
      while(k < count)
      {
         if(arr[k]  != tmp)
            break;
         k++;
      }
   }
   return 0; // значение не нйдено
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.10.2018, 23:59
Помогаю со студенческими работами здесь

Даны числа a, b, c. Если все они равны нулю, вывести об этом сообщение, если среди чисел нет нулей, найти и вывести их произведение, в противном случа
Всем привет. Будьте добры, подсобите в написании программки: &quot;Даны числа a, b, c. Если все они равны нулю, вывести об этом сообщение,...

Заменить в массиве все нечетные числа на 1. Если нечетных чисел нет, то вывести сообщение об этом
Добрый день! Помогите пожалуйста с программой на QBasic, Максимальный элемент осилил, нечетные числа заменил на 1, а вот вывести сообщение...

В целочисленном массиве найти минимальный элемент среди нечетных и максимальный элемент среди четных элементов
Помогите пожалуйста :help: Задание: В целочисленном массиве X найти минимальный элемент среди нечетных и максимальный элемент среди...

В целочисленном массиве M(n) найти максимальный элемент среди четных элементов массива и максимальный элемент
В целочисленном массиве M(n) найти максимальный элемент среди четных элементов массива и максимальный элемент среди нечетных элементов...

В массиве R(k) найти минимальный элемент среди положительных и максимальный среди отрицательных
В массиве R(k) найти минимальный элемент среди положительных и максимальный среди отрицательных


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru