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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Найти координаты 4 вершины http://www.cyberforum.ru/cpp-beginners/thread967372.html
Та же самая задача, только на Си http://www.cyberforum.ru/turbo-pascal/thread517467.html помогите исправить ошибки, уже умучелся с ней возиться #include <stdio.h> #include <math.h> int...
C++ Сформировать целочисленный массив Сформировать целочисленный массив размерности n. Значение n вводится с клавиатуры, массив заполняется случайными числами, равномерно распределенными в интервале -99..0. Вывести на печать (в... http://www.cyberforum.ru/cpp-beginners/thread967366.html
C++ С чего стоить начать изучение С++
Здравствуйте. Помогите пожалуйста, очень хочу начать изучение С++, но не знаю с чего начать. С какой литературы, уроков начинать? Какой средой разработки пользоваться? (Опыта других ЯП не...
Определить и напечатать произведение отрицательных компонентов вектора C++
Помогите написать программу, Дан действительный вектор x , n <= 100. Определить и напечатать произведение отрицательных компонентов вектора.
C++ Определить количество элементов массива, меньших среднего арифметиче-ского значений элементов этого массива http://www.cyberforum.ru/cpp-beginners/thread967359.html
Времени нет , только ещё учу . нужно сделать срочно работы . углубился в учебник пока , но не успеваю разобраться . может есть добрые люди , не откажут в помощи ? профи тут полно . хотелось...
C++ Задана действительная матрица aij Задана действительная матрица aij размерности n×m. Написать программу, которая определяет действительные числа b1, b2, …, bn, равные значениям средних геометрических элементов строк матрицы. подробнее

Показать сообщение отдельно
apowOw
0 / 0 / 0
Регистрация: 02.10.2013
Сообщений: 21

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

02.10.2013, 18:39. Просмотров 1508. Ответов 6
Метки (Все метки)

Хотелось бы выразить большую благодарность Croessmah'у за оказанную помощь.
Позвольте ещё раз обратиться за помощью:

В одномерном массиве, состоящем из n вещественных элементов, вычислить:
1.) максимальный по модулю элемент массива;
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#include "stdafx.h"
#include <stdio.h>
#include <math.h>
#include <windows.h>
#include <conio.h>
#include <stdlib.h>
       
 
 
int main(void)
{
    int n, i;
printf("\nVvedite koli4estvo elementov massiva",n);
    double *mas = new double[n];
    for(i = 0; i < n; ++i)
     scanf("%f",&mas[i]);
        double max, sum, tmp;
        int maxi, j;
        printf("\nIshodniy massiv:\n");
        for ( i = 0; i < n; ++i )
                printf("mas[%d] = %5.1f\n", i, mas[i]);
      
     
        maxi = 0;
        max = fabs(mas[maxi]);
        for ( i = 1; i < n; ++i ){
                if ( max < fabs(mas[i]) ){
                        maxi = i;
                        max = fabs(mas[maxi]);
                }
        }
        printf("\nMaksimalniy po module element:\nmas[%d] = %.1f\t%.1f\n", maxi, mas[maxi], max); 
        
  
        i = 0;
        sum = 0.0;
        while ( mas[i] < 0  && i < n )
                ++i;
        if ( i == n ){
                printf("\nV massive net pologitelnih elementov\n");
                goto THREE;
        }
        ++i; 
        while ( mas[i] < 0 && i < n )
                sum += mas[i++];
        if ( i == n ){
                printf("\nV massive tolko odin pologitelniy element\n");
                goto THREE;
        }
        printf("\nSumma elementov mejdu pervim i vtorim pologitelnimi elmentami ravna %.1f\n", sum);
        
 
        THREE:
 
        for ( j = n - 1; j >=0 && mas[j] == 0.0; --j )
                ;
        if ( j < 0 ){
                printf("\nVse elementi v massive nulevie\n");
                return 0;
        }
        for ( i = 0; i < j; ++i ){
                while ( mas[i] == 0 && i < j ){
                        tmp = mas[i];
                        mas[i] = mas[j];
                        mas[j--] = tmp;
                }
        }
 
        printf("\nVse nuli v konce massiva\n");
        for ( i = 0; i < n; ++i )
                printf("mas[%d] = %5.1f\n", i, mas[i]); 
        
      
        getch ();
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru