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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ циклы функций isdigit, insert http://www.cyberforum.ru/cpp-beginners/thread193060.html
никак не могу разобраться как дописать следующие функции: int isdigit(char c) { insert(char *s, char c, int i) {
C++ Запись массива в dat файл Хочу записать большой массив в dat файл но получаю ошибку error C2070: int : недопустимый оператор sizeof если делаю массив чуть поменьше то все проходит без ошибок int card_5={0}; FILE * fout = fopen("card_5_ryka.dat", "wb"); fwrite(card_5, sizeof(card_5), 1, fout); fclose(fout); http://www.cyberforum.ru/cpp-beginners/thread193032.html
C++ сортировка строк текста
этот код выносит мне мозг, разные компиляторы читают его по-разному, ошибка очевидно в функции gets или я ошибаюсь? задачка: вводим с клавиатуры текст в конце каждой строки enter, признаком конца набора служит пустая строка. далее эти строки требуется отсортировать. вот мой код: #include <stdio.h> #include <conio.h> #include <string.h> #define Nmax 50; void main()
C++ Проверить код на корректность
Сделал лабу, все работает отлично.... Но я не уверен что она написана нормально, может где то переменная не там обявляется или не так передается , может функция какая то не так написана... проверте , буду очень благодарен )) #include <iostream> #include <cstdlib> #include<clocale> #include <fstream> #include <conio.h> using namespace std; struct LIST {
C++ количество пробелов в двух строках http://www.cyberforum.ru/cpp-beginners/thread192972.html
Здравствуйте. Пожалуйста, помогите кто-нибудь с задачей. Требуется написать программу с классами и объектами которая считает количество пробелов в двух строках, сравнивает их, и выводит сообщение на экран о том, что в какой-то из строк пробелов больше. Спасибо.
C++ нахождение максимального значение в матрице доброго всем прекрасного время суток.. у меня такой вопрос.. есть ли способ быстро найти елемент с максимальным значением в матрице.. тоесть.. как еще можно найти этот елемент.. не сравнивая поочередно и попарно каждые два соседних числа матрици. Ведь это значительно уменшает время нахождения.... и ужасно загромождает структуру кода программы. заранее Биг вам спасибо =)) подробнее

Показать сообщение отдельно
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9372 / 5422 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
18.11.2010, 01:55     Найти сумму модулей элементов массива, расположенных после первого положительного
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
94
95
96
97
98
99
100
#include <iostream>
#include <cmath>
 
/*  В одномерном массиве, состоящем из n вещественных элементов, вычислить:
1. номер максимального по модулю элемента массива;
2. сумму модулей элементов массива, расположенных после первого положительного элемента.
Преобразовать массив таким образом, чтобы сначала располагались все элементы, целая часть которых 
лежит в интервале , а потом – все остальные.    */
    
// возвращает указатель на максимальный по модулю элемент
double * fabs_max(double * arr, size_t size){
    return ( size == 1 ) ? arr : ( fabs(*arr) > fabs(*(arr + size - 1)) ) ? fabs_max(arr, size - 1) : fabs_max(arr + 1, size - 1);
}
 
// возвращает сумму модулей элементов массива
double fabs_sum(double * arr, size_t size){
    double sum(0.0);
    while ( size-- )
        sum += fabs(*arr++);
    return sum;
}
 
// возвращает true, если целая часть элемента находится в заданном диапазоне
bool in_range(double val, double low, double high){
    val = floor(val);
    return ( val >= low && val <= high );
}
 
// переставляет элементы в массиве. не эффективна при больших размерах массивов,
// за то не использует стандартные классы С++, типичный велосипед
void sort_by_range(double * arr, size_t size, double low, double high){
    double * inRange = new double [ size ];
    double * outRange = new double [ size ];
    size_t cntInRange(0), cntOutRange(0);
    
    for ( size_t i = 0; i < size; ++i ){
        if ( in_range(arr[i], low, high) )
            inRange[cntInRange++] = arr[i];
        else
            outRange[cntOutRange++] = arr[i];
    }
    
    for ( size_t i = 0; i < cntInRange; ++i )
        *arr++ = inRange[i];
    for ( size_t i = 0; i < cntOutRange; ++i )
        *arr++ = outRange[i];
    
    delete [] inRange;
    delete [] outRange;
}
 
// выводит массив
void dump(double * arr, size_t size){
    while ( size-- )
        std::cout << *arr++ << " ";
    std::cout << std::endl;
}
 
int main(){
    double * arr;
    size_t size;
    
    std::cout << "Number of elements: ";
    std::cin >> size;
    arr = new double [ size ];
    for ( size_t i = 0; i < size; ++i ){
        std::cout << "Element #" << ( i + 1 ) << ": ";
        std::cin >> arr[i];
    }
    
    std::cout << "\nYou have entered:" << std::endl;
    dump(arr, size);
    
    double * fabsMax = fabs_max(arr, size);
    std::cout << "Maximum value on the unit " << *fabsMax << " contains an element #" << ( fabsMax - arr + 1 ) << std::endl;
    
    size_t firstPositiveIndex;
    for ( firstPositiveIndex = 0; firstPositiveIndex < size; ++firstPositiveIndex )
        if ( arr[firstPositiveIndex] > 0.0 )
            break;
    if ( firstPositiveIndex == size )
        std::cout << "No positive elements in array." << std::endl;
    else if ( firstPositiveIndex == size - 1 )
        std::cout << "First positive element is last in array." << std::endl;
    else 
        std::cout << "The total of units of elements after first positive is " 
                << fabs_sum(&arr[firstPositiveIndex] + 1, size - firstPositiveIndex - 1) << std::endl;
    
    double low, high;
    std::cout << "Low watermark: ";
    std::cin >> low;
    std::cout << "High watermark: ";
    std::cin >> high;
    sort_by_range(arr, size, low, high);
    std::cout << "Separated by range:" << std::endl;
    dump(arr, size);
    
    delete [] arr;
    return 0;
}
 
Текущее время: 01:24. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru