Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.52/58: Рейтинг темы: голосов - 58, средняя оценка - 4.52
0 / 0 / 0
Регистрация: 22.12.2010
Сообщений: 3
1

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

22.12.2010, 22:48. Просмотров 11396. Ответов 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 минут
помогите пожалуйста..
завтра надо сдавать,иначе мне

подскажите в каком направлении мыслить
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
22.12.2010, 22:48
Ответы с готовыми решениями:

Сортировка четных, а затем нечетных элементов массива по возрастанию
Помогите пожалуйста отсортировать массив. Сначала четные по возрастанию, а затем нечетные по...

Сортировка четных столбцов матрицы по убыванию элементов, а нечетных - по возрастанию
Дана матрица, размерностью nxn, содержащая целые числа. Отсортировать каждый столбец матрицы с...

Найти суммы четных элементов (элементов с четным номером) массива вещественных чисел A(22) и нечетных элементов
Здравствуйте, дорогие форумчане. Не могли бы вы мне помочь? Мне нужно составить программу с таким...

Определить сумму указанных элементов, количество нечетных элементов и среднее арифметическое четных элементов массива
Дан двумерный массив целых чисел. Определить: 1. Сумму элементов массива, больших 30 2....

1
302 / 160 / 62
Регистрация: 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;
}
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
23.12.2010, 10:32

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Найти отношение количества четных элементов к количеству нечетных элементов динамического массива
Написать программу, использующую потоки cout и cin для ввода/вывода. Программа должна использовать...

Создать 2 массива из четных и нечетных элементов исходного массива
Дан массив F из n целых случайных чисел. Выбрать из него в массив W все четные элементы, а в массив...

Cумма чётных и нечётных элементов массива
В программе нужно посчитать сумму чётных элементов(S2) и нечётных(S1) при их выводе они получаются...

Вывести на консоль значения чётных элементов массива, сумму индексов нечётных элементов, и исходный массив
Написать программу, которая выводит значения четных элементов массива, сумму индексов нечетных...


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

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

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