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

Найти в массива максимальный, положительный и нулевые элементы - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Реализовать класс "наследник" http://www.cyberforum.ru/cpp-beginners/thread1776530.html
Spisok.h #pragma once class Spisok { int size1; int size2; int **mas; public: Spisok(int,int);
C++ WinAPI Поместить курсор в произвольную позицию в консоли. SetConsoleCursorPosition Как работает? Мне нужно, чтобы можно было курсор поставить в любое место выводимого на экран массива. http://www.cyberforum.ru/cpp-beginners/thread1776461.html
C++ Ошибка LNK 2019 - C++ (Visual Studio 2011)
Доброго времени суток. Помогите пожалуйста разобраться. Не удается запустить проект из 3-х файлов. Проект создавался "пустой". Если весь код написать в одном файле - работает, а если в разных - нет. Текст файла MyMain.cpp (с функций main) ______________________________________ #include <iostream> #include <time.h> #include <conio.h> #include "MyLIFO-3.h" using namespace std; void main...
Извлечение данных из файла C++
Не могу придумать способ извлечения данных из файла с форматированием (проблема с функцией diskIn(pn)). Нужно чтобы функция умела извлекать определенную запись. #include<iostream> #include<fstream> #include<process.h> using namespace std; const int sz=20; class cname { private: char name; char sname;
C++ Сдвиг столбцов матрицы http://www.cyberforum.ru/cpp-beginners/thread1776405.html
Добрый вечер. Может кто помочь со следующей задачей? Заполнить двумерный массив случайными числами и показать на экран. Сдвинуть все столбцы массива на X позиций (число X вводит пользователь) влево. Например, если Х=2, то массив: 1 2 3 4 5 5 6 7 8 9 6 7 8 9 0 примет следующий вид: 3 4 5 1 2 7 8 9 5 6 8 9 0 6 7
C++ Не открывается файл для чтения Не могу разобраться с кодом , не получается прописать входной фаил , не принимает его .. #include <stdio.h> #include <math.h> #define MAX 100 double x, y; int n; подробнее

Показать сообщение отдельно
Головолом
0 / 0 / 0
Регистрация: 29.12.2015
Сообщений: 15
06.07.2016, 10:43     Найти в массива максимальный, положительный и нулевые элементы
Здравствуйте!
Пожалуйста, помогите отредактировать текст программы.
Задание вот такое:
1) Найти максимальный по модулю элемент массива.
2) Найти сумму элементов массива, расположенных между первым и вторым положительными элементами.
3) Преобразовать массив таким образом, чтобы элементы, равные нулю, располагались после всех остальных.

Текст программы:
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#include <stdio.h>
#include <conio.h>
#include <iostream>
#include <windows.h>
#include <math.h>
#include <algorithm>
using namespace std;
int main()
{
    setlocale(LC_ALL, "Russian");
    int kol_a;
    cout << "Приветствую пользователь!" << endl;
    cout << "Введите количество элементов: " << endl;
    cin >> kol_a;
    if (kol_a < 0)
    {
        cout << " Введено отрицательное число\n";
        system("PAUSE");
        return 0;
    }
    int *a;
    a = new int[kol_a];
    cout << "Введите элементы массива: " << endl;
    for (int i = 0; i < kol_a; i++) cin >> a[i];
    int max = 0, imax = 0;
    for (int i = 0; i < kol_a; i++)
    {
        if (abs(a[i])>abs(a[imax]))
        {
            imax = i; max = a[imax];
        }
    }
    int ipos = -1;
    int ipos2 = -1;
    for (int i = 0; i < kol_a; i++)
        if (a[i] > 0)
        {
            ipos = i;
            break;
        }
 
    if (ipos == -1) cout << "Положительных элементов нет!\n";
    else if (ipos == kol_a - 1) cout << "Положительный элемент - последний!\n";
    else {
        double sum = 0;
        for (int i = ipos + 1; i < kol_a; i++)
            if (a[i] > 0)
            {
                ipos2 = i;
                break;
            }
        for (int i = ipos + 1; i < ipos2; i++)
        {
            sum += a[i];
        }
        int *stackl = new int[kol_a], *stackr = new int[kol_a];
        int sp = 1;  stackl[sp] = 0;  stackr[sp] = kol_a - 1;
        while (sp > 0) 
        {                
            int left = stackl[sp];
            int right = stackr[sp];
            sp--;
 
            while (left < right)
            {
            int i = left, j = right;
                float middle = a[(left + right) / 2];
                while (i < j) 
                {
                    while (a[i] < middle) i++;
                    while (middle < a[j]) j--;
                    if (i <= j)
                    {
                        float temp = a[i]; a[i] = a[j]; a[j] = temp;
                        i++; j--;
                    }
                                }
                if (i < right)
                {           
                    sp++;
                    stackl[sp] = i;
                    stackr[sp] = right;
                }
                right = j;            
            }
        }
        for (int i = 0; i < kol_a; i++) cout << a[i] << ' ';
        cout << endl << "Сумма элементов между первыми положительными: " << sum << endl;
        cout << "Максимальный элемент по модулю: " << max << endl;
        system("PAUSE");
        return 0;
    }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 22:39. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru