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

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

24.05.2013, 13:46. Показов 5670. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
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 - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru