Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
detSD
0 / 0 / 0
Регистрация: 22.04.2013
Сообщений: 16
#1

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

24.05.2013, 13:46. Просмотров 1056. Ответов 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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.05.2013, 13:46
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Найти максимальный отрицательный и минимальный положительный элемент и поменять их местами (C++):

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

Поменять местами максимальный отрицательный и первый положительный элементы массива - C++
Использовать обращение к элементам массива с помощью операции индексации и через указатель. При выводе матриц следить за тем, чтобы ширина...

Поменять местами первый отрицательный и последний положительный элемент массива - C++
Поменять местами первый отрицательный и последний положительный елемент массива. Учесть возможность того, что отрицательные или...

Найти в массиве максимальный элемент и минимальный элемент, и поменять их местами - C++
Привет) помогите пожалуйста решить задачу. Дан целочисленный массив из m элементов. Найдите в нем максимальный элемент и минимальный...

Найти максимальный и минимальный элемент массива и поменять их местами - C++
Задан массив целых чисел. Найти максимальный и минимальный элемент массива и поменять их местами Добавлено через 46 минут Написать...

Матрица, найти и поменять местами минимальный и максимальный элемент - C++
Помогите с задачей: В квадратной матрице A найти среди элементов, расположенных ниже главной диагонали, минимальный элемент, а среди...

7
dstat
36 / 38 / 1
Регистрация: 01.06.2011
Сообщений: 238
24.05.2013, 14:27 #2
потому что вы выводите тот же массив в конце, а не найденные элементы
1
detSD
0 / 0 / 0
Регистрация: 22.04.2013
Сообщений: 16
24.05.2013, 22:24  [ТС] #3
dstat, я вписал в цикл, все равно выводит, тот же самый ответ
0
Belfegor
Ghost
173 / 173 / 6
Регистрация: 16.09.2012
Сообщений: 526
24.05.2013, 22:47 #4
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
Issues
430 / 365 / 37
Регистрация: 06.08.2012
Сообщений: 961
24.05.2013, 23:07 #5
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
vetal0007
29 / 29 / 1
Регистрация: 11.02.2012
Сообщений: 339
24.05.2013, 23:08 #6
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
Belfegor
Ghost
173 / 173 / 6
Регистрация: 16.09.2012
Сообщений: 526
24.05.2013, 23:11 #7
Цитата Сообщение от vetal0007 Посмотреть сообщение
Belfegor, У тебя чуток неправильно было, я подкорректировал и сделал, чтобы массив всегда разный был.
не у меня, а у автора
0
Recreate
32 / 32 / 1
Регистрация: 25.02.2013
Сообщений: 221
03.10.2013, 00:10 #8
задачка на внимательность. все вышеперечисленные решения не удовлетворяют условию.
Найти максимальный отрицательный и минимальный положительный элемент и поменять их местами[/B]
т.е. имея массив -5, -4, -7, -2, 1, 8, 3 нужно поменять не -5 и 8, а -2 и 1. на джаве решал данную задачку.
0
03.10.2013, 00:10
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.10.2013, 00:10
Привет! Вот еще темы с ответами:

В каждом из массивов найти минимальный положительный и и максимальный отрицательный элементы - C++
Цель: научиться использовать механизм перегрузки функций при разработке программ на языке программирования с++ Задание: Даны массивы...

Найти максимальный и минимальный элемент в каждой строке матрицы и поменять их местами - C++
Дана матрица вещественных чисел N х М. Количество строк N и столбцов М задается пользователем. Найти максимальный и минимальный элемент в...

Поменять местами минимальный элемент и первый отрицательный элемент массива целых чисел - C++
Поменять местами минимальный элемент и первый отрицательный эле-мент массива целых чисел.Необходимо использовать указатели и динамическйи...

В массиве найти минимальный положительный и максимально отрицательный элемент и вычисляет их следующее значени - C++
Очень-очень-очень срочно надо сделать такую прогу, а я не совсем понимаю как её делать. Помогите, пожалуйста. Если можно, то объясните...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru