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

Сортировка четных/нечетных элементов массива - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 37, средняя оценка - 4.97
Rubick
0 / 0 / 0
Регистрация: 22.12.2010
Сообщений: 3
22.12.2010, 22:48     Сортировка четных/нечетных элементов массива #1
В одномерном массиве состоящем из n вещественных элементов вычислить
1)...
2)...
3)упорядочить по возрастанию отдельно элементы стоящие на четных,отдельно на нечетных местах


вот такая программа.. первый 2 пункта вроде сделал,а сортировку осилить не могу



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
#include <stdafx.h>
#include <iostream>
#include <stdlib.h>
#include <math.h>
#include <stdio.h>
using std::cin;
 using std::cout;
 using std::endl;
int main() 
  {   
 int n,i,j,
        minelem;       // Номер минимального элемента
    float   proizv = 0,           // Произведение положительных элементов
            temp;
    cout << "Enter n: ";        // Ввод количества элементов массива
    cin >> n;
    float *arr = new float [n]; // Создание массива
    for (i = 0; i < n; i++){
        cout << "Enter element number " << i + 1 << " : ";      // Ввод элементов массива
        cin >> arr[i];   
 }
    minelem = 0;
    for (minelem=i=0,proizv=1;i<n;i++)
{
        if (arr[i] > 0) proizv *= arr[i];                         // Произведение положительных элементов
        if (arr[i] < arr[minelem]) minelem = i;  // Определение номера минимального элемента
         }   
  cout << "Proizv of positive elements = " << proizv << endl;     // Вывод произведения пол. елементов
    if (minelem-1 > 0){    // Если между первым и минимальным элементами есть элементы
            for (i = 0,temp = 0; i < minelem; i++)
            temp += arr[i]; // Сумма промежуточных элементов
        cout << "Summa of elements between first and min = " << temp << endl; // Вывод полученной суммы
    } 
   else        cout << "No elements between first and min.";
cout << "Source array:\n[";
    for (i = 0; i < n; i++)                         // Вывод исходного массива
        cout << arr[i] << (i < n-1 ? ", " : "]\n"); 
 
 
    // Сортировка массива .вот тут у меня проблемы(дальше идет бред)
for (i=0;i<n;i++)
    if (arr[i]>arr[i+1]) 
        {
            z=arr[i];
            arr[i]=arr[i+1];
            arr[i+1]=z;
            cout<<"chet"<<endl;
        }   else cout<<"fail"<<endl;
        cout<<"chet mass"<<endl;
    for (i=0;i<n;i++)
    cout<<arr[i]<<endl;
     _getch();
     return 0;
}
Добавлено через 4 часа 49 минут
помогите пожалуйста..
завтра надо сдавать,иначе мне

подскажите в каком направлении мыслить
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.12.2010, 22:48     Сортировка четных/нечетных элементов массива
Посмотрите здесь:

C++ Найти сумму четных и произведение нечетных элементов массива
C++ Найти сумму элементов четных строк и произведение элементов нечетных строк массива
C++ Создать 2 массива из четных и нечетных элементов исходного массива
C++ количество четных элементов одномерного массива до числа равному а, Определить количество нечетных элементов двумерного массива
C++ Найти суммы четных элементов (элементов с четным номером) массива вещественных чисел A(22) и нечетных элементов
C++ Вывод элементов массива, стоящих на четных позициях, а затем – на нечетных
Вычислить количество элементов массива, стоящих на четных и нечетных позициях C++
C++ Определить сумму указанных элементов, количество нечетных элементов и среднее арифметическое четных элементов массива

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
NNN777
299 / 157 / 19
Регистрация: 27.02.2010
Сообщений: 317
23.12.2010, 10:32     Сортировка четных/нечетных элементов массива #2
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
#include<iostream>
#include<time.h>
using namespace std;
 
 
int main()
{
    srand(time(NULL));
    const int n=9;
    int i, j, buf, k, p;
    int a[n]={1,2,3,4,5,6,7,8,9};
    for(i=0; i<n; i++)
    {
        //a[i]=rand()%10;
        cout<<a[i]<<" ";
    }
    cout<<endl;
    k=n-1;
    p=n-2;
    if (n%2==0)
    {
        k=n-2;
        p=n-1;
    }
    for(i=0; i<n-2; i+=2)
        for(j=k; j>i; j-=2)
            if(a[j]>a[j-2])
            {
                buf=a[j];
                a[j]=a[j-2];
                a[j-2]=buf;
            }
    for(i=1; i<n-2; i+=2)
        for(j=p; j>i; j-=2)
            if(a[j]>a[j-2])
            {
                buf=a[j];
                a[j]=a[j-2];
                a[j-2]=buf;
            }
    cout<<"REZ: "<<endl;
    for(i=0; i<n; i++)
        cout<<a[i]<<" ";
    cout<<endl;
 
    return 0;
}
Yandex
Объявления
23.12.2010, 10:32     Сортировка четных/нечетных элементов массива
Ответ Создать тему
Опции темы

Текущее время: 16:43. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru