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

Найти максимальный отрицательный и минимальный положительный элемент и поменять их местами

24.05.2013, 13:46. Показов 5692. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
1) Дан массив из 20 чисел найти максимальный отрицательный и минимальный положительный элемент, поменять их местами.

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
#include <iostream>
#include <conio.h>
 
using namespace std;
 
int main()
{
    setlocale(LC_ALL,"russian");
    int a[20];
    int c;
    int min = 10000;
    int max = -10000;
    cout << "Ìàññèâ À: ";
    for(int i = 0; i < 5; i++)
    { 
      a[i] = rand() % 50-10;
      cout << a[i] << " "; }
    
    for(int i = 0; i < 20; i++)
    {      
           if(min >= a[i] && a[i] < 0)
                   {
                          min = a[i];
                   }
           if(max <= a[i] && max > 0)
                   {
                          max = a[i];
                   }    
           c = max;
           max = min;
           min = c;
    }
    cout << endl << endl;
    cout << "Èçìåíåííûé ìàññèâ À: ";
    for(int i = 0; i < 5; i++)
            { cout << a[i] << " "; }
    getch();
}
кому не лень, подскажите почему не работает...
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.05.2013, 13:46
Ответы с готовыми решениями:

Массивы: поменять местами минимальный по модулю элемент и максимальный отрицательный элемент
Пусть А одномерный массив N-целых чисел. Ввести его случайным образом. а) поменять местами минимальный по модулю элемент и максимальный...

Поменять местами максимальный по модулю отрицательный элемент и минимальный положительный
Поменять местами максимальный по модулю отрицательный элемент и минимальный положительный. Тестовый массив 4 5 6 7 12 -3 4 -5 -7 2...

Дан массив B[1:n]. Поменять местами его максимальный отрицательный и минимальный положительный элемент
Программа вот, Покажите пожалуйста что и как нужно исправить. Var n,max,min,i,c,j,k,b,m:integer; A:array of integer; Begin ...

7
36 / 38 / 7
Регистрация: 01.06.2011
Сообщений: 237
24.05.2013, 14:27
потому что вы выводите тот же массив в конце, а не найденные элементы
1
0 / 0 / 1
Регистрация: 22.04.2013
Сообщений: 16
24.05.2013, 22:24  [ТС]
dstat, я вписал в цикл, все равно выводит, тот же самый ответ
0
Ghost
 Аватар для Belfegor
174 / 174 / 40
Регистрация: 16.09.2012
Сообщений: 526
24.05.2013, 22:47
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<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#include<iomanip>
 
using namespace std;
 
 
const int size = 20;
 
int main() {
    int arr[size];
    for (int &x : arr) {
        x = rand() % 50 - 10;
    }
    for (int x : arr) {
        cout << x << ' ';
    }
    cout << endl;
    int min = arr[0];
    int max = arr[0];
    for (int &x : arr) {
        if (x < min && x < 0)min = x;
        if (x > max && x > 0)max = x;
    }
 
 
    cout << "min: " << min << " max: " << max << endl;
    for (int &x : arr) {
        if (x == max)x = min;
        if (x == min)x = max;
    }
    for (int x : arr) {
        cout << x << ' ';
    }
    cout << endl;
 
    return 0;
}
1
433 / 368 / 149
Регистрация: 06.08.2012
Сообщений: 961
24.05.2013, 23:07
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
#include <algorithm>
#include <iostream>
#include <vector>
 
void PRINT(const int elem) { std::cout << elem << ' '; }
 
int main()
{
    const int size = 20;
    int a[size] = { 20, 15, 60, 40, 10, 90, 53, 23, 12, 55, 98, 12, 11, 56, 565, 66, 67, 454, 3, 87 };
    
    std::for_each(a, a+size, PRINT); std::cout << std::endl;
 
    std::cout << "Replace Min and Max. \n";
 
    std::pair<int*, int*> mm = std::minmax_element(a, a+size);
 
    *mm.first  = *mm.second ^ *mm.first;
    *mm.second = *mm.second ^ *mm.first;
    *mm.first  = *mm.second ^ *mm.first;
    
    std::for_each(a, a+size, PRINT); std::cout << std::endl;
 
    system("PAUSE");
    return 0;
}
2
29 / 29 / 3
Регистрация: 11.02.2012
Сообщений: 339
24.05.2013, 23:08
Belfegor, У тебя чуток неправильно было, я подкорректировал и сделал, чтобы массив всегда разный был.


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
#include "stdafx.h"
#include <iostream>
#include <iomanip>
#include <conio.h>
 using namespace std;
  
const int size = 20;
 
int main() {
    srand(time(NULL));
    int arr[size];
    for (int &x : arr) {
        x = rand() % 50 - 10;
    }
    for (int x : arr) {
        cout << x << ' ';
    }
    cout << endl;
    int min = arr[0];
    int max = arr[0];
    for (int &x : arr) {
        if (x < min && x < 0)min = x;
        if (x > max && x > 0)max = x;
    }
 
 
    cout << "min: " << min << " max: " << max << endl;
    for (int &x : arr) {
        if (x == max) {x = min; min=max;max=x;}
        if (x == min) {x = max; max=min;min=x;}
    }
    for (int x : arr) {
        cout << x << ' ';
    }
    cout << endl;
    system ("pause");
    return 0;
}
1
Ghost
 Аватар для Belfegor
174 / 174 / 40
Регистрация: 16.09.2012
Сообщений: 526
24.05.2013, 23:11
Цитата Сообщение от vetal0007 Посмотреть сообщение
Belfegor, У тебя чуток неправильно было, я подкорректировал и сделал, чтобы массив всегда разный был.
не у меня, а у автора
0
34 / 34 / 5
Регистрация: 25.02.2013
Сообщений: 221
03.10.2013, 00:10
задачка на внимательность. все вышеперечисленные решения не удовлетворяют условию.
Найти максимальный отрицательный и минимальный положительный элемент и поменять их местами[/B]
т.е. имея массив -5, -4, -7, -2, 1, 8, 3 нужно поменять не -5 и 8, а -2 и 1. на джаве решал данную задачку.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
03.10.2013, 00:10
Помогаю со студенческими работами здесь

В массиве целых чисел поменять местами максимальный отрицательный элемент и минимальный положительный
В массиве целых чисел поменять местами максимальный отрицательный элемент и минимальный положительный. Вывести сначала оригинальный массив...

Поменять местами максимальный положительный и минимальный отрицательный элементы массива
Одномерный массив: Поменять местами максимальный положительный и минимальный отрицательный элементы массива Т(14)

Поменять местами максимальный отрицательный и первый положительный элемент массива В(18)
поменять местами максимальный отрицательный и первый положительный элемент массива В(18)

Найти максимальный отрицательный элемент и минимальный положительный элемент
Как создать условие, чтобы найти максимальный отрицательный элемент и минимальный положительный элемент? Я беру матрицу...

Найти минимальный положительный и максимальный отрицательный элемент и ещё много чего
В одномерных массивах X и Y найти минимальный положительный и максимальный отрицательны


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3 из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru