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

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

Войти
Регистрация
Восстановить пароль
 
vikichocolate
25 / 14 / 1
Регистрация: 11.11.2011
Сообщений: 94
#1

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

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

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

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

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

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

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

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

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

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


пользуюсь отлидчиком...не нахоже еще пока в чем проблема
0
Mиxaил
533 / 438 / 37
Регистрация: 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
amor1k
Студент
147 / 147 / 24
Регистрация: 18.01.2011
Сообщений: 469
11.11.2011, 23:52 #5
измените строку 32 на
C++
1
for (unsigned int j=0; j<size; j++)
1
vikichocolate
25 / 14 / 1
Регистрация: 11.11.2011
Сообщений: 94
12.11.2011, 00:25  [ТС] #6
спасибо большое!!!!!
0
12.11.2011, 00:25
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
12.11.2011, 00:25
Привет! Вот еще темы с ответами:

Поменять местами во всех строках последний нулевой элемент и первый минимальный - C++
Ввести в память машины двумерный целочисленный массив, размером M*N. 3&lt;=M&lt;=10; 3&lt;=N&lt;=10. Вывести на экран исходный массив и данные,...

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

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

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


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

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

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