Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
25 / 14 / 4
Регистрация: 11.11.2011
Сообщений: 94
1

Поменять первый максимальный и последний минимальный элемент массива

11.11.2011, 23:15. Показов 1009. Ответов 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
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
53
54
55
56
57
58
59
60
61
62
63
64
#include <iostream>
using namespace std;    
int findMax(int *A, unsigned int size) // функция нахождения максим элемента
{
if (A==NULL && size==0)
        return 0;
 
    int result = A[0];
    int imax=0;
 
    for (unsigned int i=0; i<size; i++)
    {
        if (A[i]>result)
        {
            result = A[i];
            imax=i; // запоминание значения
            break;
        }
    }
//cout<<result<<endl;
    return imax;
}
 
int findMin(int *A, unsigned int size) // фанкция нахождения минимального элемента
{
    if (A==NULL && size==0)
        return 0;
 
    int result = A[0];
    int imin=0;
 
    for (unsigned int j=size; j>0; j--)
    {
        if (result>=A[j])
        {
            result=A[j];
            imin=j;
            //break;
        }
    }
//cout<<result<<endl;
    return imin;
}
 
 
 
void main()
{   
    int n=0; // число элементов массива
    int temp=0;     //переменная для обмена значений
    printf("please, enter n \n"); 
    cin>>n;  
    int  *a=new int[n] ;
    printf("please, enter array \n"); 
    for(int i=0; i<n; i++)
        cin>>a[i]; 
    int imin = findMin(a, n); // вызов функции
    int imax = findMax(a, n); // вызов функции
            temp=a[imax]; // обмен значений 
         a[imax]=a[imin];
         a[imin]=temp;
    for(int j=0; j<n; j++) 
        cout<<a[j]<<' ';// вывод массива
}
0

Помощь в написании контрольных, курсовых и дипломных работ здесь.

Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
11.11.2011, 23:15
Ответы с готовыми решениями:

Поменять местами первый минимальный и последний максимальный элементы массива
&quot;Дан одномерный целочисленный массив из N элементов, заданных случайными числами на промежутке [a;...

Поменять местами первый минимальный и последний максимальный элементы массива
В среде MS Visual C++ разработать программу, которая формирует одномерный целочисленный массив из N...

Поменять местами первый максимальный четный элемент массива и первый минимальный нечетный элемент
Помогите начало знаю как сделать а дальше нет #include&lt;iostream&gt; #include &lt;stdlib.h&gt; #include...

Поменять местами первый минимальный и последний максимальный элементы заданного одномерного массива
Поменять местами первый минимальный и последний максимальный элементы массива.

5
Каратель
Эксперт С++
6601 / 4020 / 401
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
11.11.2011, 23:20 2
Цитата Сообщение от vikichocolate Посмотреть сообщение
Посмотрите, пожалуйста, где тут ошибка
что говорит компилятор?
1
25 / 14 / 4
Регистрация: 11.11.2011
Сообщений: 94
11.11.2011, 23:24  [ТС] 3
все его устраивает. просто в отсортированном массиве один элемент с мусором

на тест 1 1 1 2 2 2
выводит 1 1 1 2 -314.. 2


пользуюсь отлидчиком...не нахоже еще пока в чем проблема
0
538 / 443 / 162
Регистрация: 10.12.2009
Сообщений: 1,857
11.11.2011, 23:39 4
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>
 
int main()
{
    int arr[] = { 3, 1, 4, 5, 2, 3, 5, 4, 4 };
    std::vector < int > v ( arr, arr + sizeof ( arr ) / 4 );
 
    auto itMin = std::find ( v.begin(), v.end(), *std::min_element ( v.begin(), v.end() ) );
    auto itMax = std::find ( v.rbegin(), v.rend(), *std::max_element ( v.begin(), v.end() ) );
    
    std::iter_swap ( itMin, itMax );
 
    std::copy ( v.begin(), v.end(), std::ostream_iterator < int > ( std::cout, " " ) );
 
    return 0;
}
1
Студент
148 / 148 / 64
Регистрация: 18.01.2011
Сообщений: 469
11.11.2011, 23:52 5
измените строку 32 на
C++
1
for (unsigned int j=0; j<size; j++)
1
25 / 14 / 4
Регистрация: 11.11.2011
Сообщений: 94
12.11.2011, 00:25  [ТС] 6
спасибо большое!!!!!
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
12.11.2011, 00:25

Найти первый минимальный и последний максимальный элементы массива. Поменять местами столбцы, содержащие эти элементы
Найти первый минимальный и последний максимальный элементы массива. Поменять местами столбцы,...

Поменять в массиве местами первый максимальный и последний минимальный элементы
помогите пожалуйста

Массивы. Поменять местами первый минимальный и последний максимальный элементы
Условие: Дана последовательность из n действительных чисел. Замечание: Решить используя...

Поменять в списке местами первый минимальный и последний максимальный элементы
односвязный список stl (c++) На основе данных входного файла создать список. Поменять в списке...


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

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

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