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

Поменять местами максимальное и минимальное значения в двух массивах

09.05.2018, 12:50. Показов 835. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, возникла небольшая проблема с данной программой. Она должна находить максимальное значение в массиве a и минимальное в массиве b, после этого поменять их местами. Но почему-то из второго массива на замену идёт не минимальное значение. Ниже скриншот. Надеюсь, что кто-нибудь поможет)
P.S: и ещё при возможности помогите создать функцию для обмена значениями в этой программе.

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
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
#include <iostream>
int main()
{
setlocale( LC_ALL,"Russian" );
const int N=3;
const int H=3;
int a[N], b[H], i=0, j=0, temp, i_max=0, j_min=0;
srand(time(NULL));
printf("Первый массив:");
for (i=0; i<N; i++)
{
    a[i]=rand()%100 +1;
    printf("\n%d",a[i]);
}
printf("\nВторой массив:");
for (j=0; j<H; j++)
{
    b[j]=rand()%100 +1;
    printf("\n%d",b[j]);
}
 for (i=1; i<N; i++)
 {
     if (a[i]>a[i_max])
         i_max=i;
 }
 for (j=1; j<H; j++)
 {
     if (b[H]<a[j_min])
         j_min=j;
 }
 temp=a[i_max]; 
 a[i_max]=b[j_min]; 
 b[j_min]=temp;
 printf("\n\n");
printf("Массивы с заменой:\n");
for (i=0; i<N; i++)
{
    printf("%d\n",a[i]);
}
for (j=0; j<H; j++)
{
    printf("\n%d ",b[j]);
} 
return 0;
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.05.2018, 12:50
Ответы с готовыми решениями:

В массиве поменять местами его максимальное и минимальное значения
В массиве из 15 вещественных чисел поменять местами его максимальное и минимальное значения.

Поменять местами минимальное и максимальное значения массива
Задача такая: 1. Создаёт динамический (либо статический) массив 2. Заполняет его рандомными числами либо они вводятся с клавиатуры (по...

Сформировать дерево и поменять местами максимальное и минимальное значения
Сформировать дерево T и поменять местами максимальное и минимальное значения.

2
447 / 333 / 172
Регистрация: 01.07.2015
Сообщений: 1,161
09.05.2018, 13:17
C++
1
for (i=1; i<N; i++)
индексация с нуля должна быть

C++
1
if (b[H]<a[j_min])
тут тоже какое-то странное условие

Вот вроде исправленное:

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
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
#include <iostream>
int main() {
  setlocale(LC_ALL, "Russian");
  const int N = 3;
  const int H = 3;
  int a[N], b[H], i = 0, j = 0, temp, i_max = 0, j_min = 0;
  srand(time(NULL));
  printf("Первый массив:");
  for (i = 0; i < N; i++) {
    a[i] = rand() % 100 + 1;
    printf("\n%d", a[i]);
  }
  printf("\nВторой массив:");
  for (j = 0; j < H; j++) {
    b[j] = rand() % 100 + 1;
    printf("\n%d", b[j]);
  }
  for (i = 0; i < N; i++) {
    if (a[i] > a[i_max])
      i_max = i;
  }
  for (j = 0; j < H; j++) {
    if (b[j] < b[j_min])
      j_min = j;
  }
  temp = a[i_max];
  a[i_max] = b[j_min];
  b[j_min] = temp;
  printf("\n\n");
  printf("Массивы с заменой:\n");
  for (i = 0; i < N; i++) {
    printf("%d\n", a[i]);
  }
  for (j = 0; j < H; j++) {
    printf("\n%d ", b[j]);
  }
  return 0;
}
Добавлено через 3 минуты
Цитата Сообщение от Dmitriy3211 Посмотреть сообщение
помогите создать функцию для обмена значениями в этой программе
Примерно так?

C++
1
2
3
4
5
void swap(int& a, int& b) {
  int t = b;
  b = a;
  a = t;
}
Вот полный код:

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
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
#include <iostream>
 
void swap(int& a, int& b) {
  int t = b;
  b = a;
  a = t;
}
 
int main() {
  setlocale(LC_ALL, "Russian");
  const int N = 3;
  const int H = 3;
  int a[N], b[H], i = 0, j = 0, temp, i_max = 0, j_min = 0;
  srand(time(NULL));
  printf("Первый массив:");
  for (i = 0; i < N; i++) {
    a[i] = rand() % 100 + 1;
    printf("\n%d", a[i]);
  }
  printf("\nВторой массив:");
  for (j = 0; j < H; j++) {
    b[j] = rand() % 100 + 1;
    printf("\n%d", b[j]);
  }
  for (i = 0; i < N; i++) {
    if (a[i] > a[i_max])
      i_max = i;
  }
  for (j = 0; j < H; j++) {
    if (b[j] < b[j_min])
      j_min = j;
  }
  //temp = a[i_max];
  //a[i_max] = b[j_min];
  //b[j_min] = temp;
  
  // С использованием написанной функции
  swap(a[i_max], b[j_min]);
  
  printf("\n\n");
  printf("Массивы с заменой:\n");
  for (i = 0; i < N; i++) {
    printf("%d\n", a[i]);
  }
  for (j = 0; j < H; j++) {
    printf("\n%d ", b[j]);
  }
  return 0;
}
1
0 / 0 / 0
Регистрация: 07.05.2018
Сообщений: 15
09.05.2018, 13:25  [ТС]
Да, огромное спасибо за помощь!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.05.2018, 13:25
Помогаю со студенческими работами здесь

Найти максимальное и минимальное значения массива и поменять их местами
Господа программисты,неофиту очень нужна ваша помощь. Дан одномерный масив D(80) Найти: максимальное и минимальное значения,и поменять...

Найти максимальное и минимальное значения элементов массива Х и поменять их местами
Найти максимальное и минимальное значения элементов массива Х и поменять их местами

Найти и поменять местами элементы, имеющие минимальное и максимальное значения в массиве
#include &lt;iostream.h&gt; #include &lt;math.h&gt; int main() { int

Найти и поменять местами элементы, имеющие минимальное и максимальное значения в массиве
Найти и поменять местами элементы, имеющие минимальное и максимальное значения в массиве.

В стеке вещественных чисел поменять местами элементы, содержащие максимальное и минимальное значения
В стеке вещественных чисел поменять местами элементы, содержащие максимальное и минимальное значения.


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
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 Использованы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru