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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
IIapa3uT
0 / 0 / 0
Регистрация: 07.02.2016
Сообщений: 25
#1

Объяснить и подробно прокомментировать фрагмент кода (функции и массивы) - C++

07.02.2016, 22:52. Просмотров 291. Ответов 5
Метки нет (Все метки)

Изучаю C++ 2 дня. Какие задачи в институте сделал сам, какие то скопировал. Данную задачу нашел на просторах интернета.
Меня интересуют именно те строки которые выше (int _tmain) Некоторые формулировки мне понятны, но массивы и работа с ними для меня глухой лес.

Сама задача:
В одномерном массиве, состоящем из n вещественных элементов, вычислить:
•количество элементов массива, лежащих в диапазоне от А до В;
•сумму элементов массива, расположенных после максимального элемента.
•Упорядочить элементы массива по убыванию модулей элементов.

Код программы (наладил, всё работает, ошибок нет). Заранее всем благодарен.
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
#include "stdafx.h"
#include <iostream>
 
using std::cin;
using std::cout;
using std::endl;
 
 
int number_within_the_limmmits(int *arr, size_t arr_sz, int left, int right){
    if (left>right){
        int tmp_i = left;
        left = right;
        right = tmp_i;
    }
    int number_whithin = 0;
    for (size_t i = 0; i < arr_sz; ++i)
        if (arr[i] >= left && arr[i] <= right) number_whithin++;//включая границы
    return number_whithin;
}
 
int ind_of_max_element(int *arr, size_t arr_sz){
    int ind_of_max = 0;
    int max_element = arr[ind_of_max];
    for (size_t i = 1; i < arr_sz; ++i){
        if (max_element < arr[i]){
            max_element = arr[i];
            ind_of_max = i;
        }
    }
    return ind_of_max;
}
 
 
int summ_arr_after_max(int *arr, size_t arr_sz){
    int ind_of_max = ind_of_max_element(arr, arr_sz);
    int summ_after_max = 0;
    for (size_t i = ind_of_max + 1; i < arr_sz; ++i)
        summ_after_max += arr[i];
    return summ_after_max;
}
 
int abs_T(int a){
    return abs(a);
}
 
 
void Sort_arr(int *arr, size_t size)  //функция сортировка по убыванию
{
    for (size_t i = 0; i<size; i++)
        for (size_t j = size - 1; j>i; j--)
            if (abs_T(arr[j - 1])<abs_T(arr[j]))
            {
                int x = arr[j - 1];
                arr[j - 1] = arr[j];
                arr[j] = x;
            }
}
 
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(LC_ALL, "");
    
 
    const int n = 6;
    int source_stat_arr[n] = {
        -13, 27, 24, 112, -101, 55
    };
    cout << "source arrays" << endl;
    for (int i = 0; i < n; ++i)cout << source_stat_arr[i] << " ";
    cout << endl << endl;
    cout << "between 15...112" << endl;
    cout << number_within_the_limmmits(source_stat_arr, n, 15, 112) << endl;//числа 15 и 112 - пределы
    cout << "summs after max" << endl;
    cout << summ_arr_after_max(source_stat_arr, n) << endl;
    cout << endl << endl;
    Sort_arr(source_stat_arr, n);
    cout << "sorted" << endl;
    for (int i = 0; i < n; ++i)cout << source_stat_arr[i] << " ";
    cout << endl << endl;
    system("pause");
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.02.2016, 22:52
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Объяснить и подробно прокомментировать фрагмент кода (функции и массивы) (C++):

Подробно прокомментировать и объяснить каждую строчку кода - C++
Если возможно по строчке распишите что делает этот кусок. 1 половина он ищет и заменяет $. а 2 что-то не пойму.

Подробно прокомментировать и объяснить каждую строчку кода - C++
Помогите пожалуйста. Нужно прокомментировать каждую строчку кода, начиная с вывода. Сам с терминологией только в общих чертах знаком, и...

Прокомментировать и подробно объяснить, что происходит в каждой строчке кода - C++
#include &lt;ctime&gt; #include &lt;iostream&gt; using namespace std; void Vvod(int* massiv,int n,int p) { int i; if (p==1) { ...

Объяснить и подробно прокомментировать, что происходит в коде (циклы и массивы) - C++
const int n=10;int i, sum; int x; cout&lt;&lt;&quot;Vvedite elementi massiva:&quot;&lt;&lt;endl; for(i=0; i&lt;n; i++)cin&gt;&gt;x; sum=0; for (i=0;i&lt;n;i++) ...

Объяснить и подробно прокомментировать каждую строчку кода (распознавание точек фигуры) - C++
Программа должна распознавать точки фигуры. Кто может объяснить, что мы делаем в каждой строчке? int main() { float * x; ...

Объяснить и подробно прокомментировать, что происходит в коде - C++
Помогите написать комментарии к каждой строке кода,желательно чтоб было объяснение,что именно происходить в строке #include &lt;iostream&gt;...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Байт
Эксперт C
15984 / 10252 / 1536
Регистрация: 24.12.2010
Сообщений: 19,336
08.02.2016, 12:04 #2
Цитата Сообщение от IIapa3uT Посмотреть сообщение
Меня интересуют именно те строки которые выше (int _tmain)
Ну, там строк довольно много, около 60-ти. Какие именно непонятны?
Tulosba
:)
Эксперт С++
4393 / 3236 / 297
Регистрация: 19.02.2013
Сообщений: 9,045
08.02.2016, 13:02 #3
Цитата Сообщение от IIapa3uT Посмотреть сообщение
number_within_the_limmmits
Код заика писал что ли?
Цитата Сообщение от IIapa3uT Посмотреть сообщение
Изучаю C++ 2 дня.
Цитата Сообщение от IIapa3uT Посмотреть сообщение
массивы и работа с ними для меня глухой лес.
Надо просто ещё почитать немного литературы.
Storm Screamer
92 / 92 / 11
Регистрация: 21.04.2013
Сообщений: 1,066
08.02.2016, 13:42 #4
Цитата Сообщение от IIapa3uT Посмотреть сообщение
Данную задачу нашел на просторах интернета.
На начальных этапах обучения копировать чужой код - ошибка. Как итог ничего не поймешь и не разберешься, особенно без теоретической части.
IIapa3uT
0 / 0 / 0
Регистрация: 07.02.2016
Сообщений: 25
09.02.2016, 01:16  [ТС] #5
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
#include "stdafx.h"
#include "iostream"
using namespace std;
 
int arr[16];
int max = -10000;
int max_num = 0;
int max_el()
{       
    for (int i = 1; i < 16;i++)
    {
        if (max < arr[i])
        {
            max > arr[i];
            max_num = i;
        }
    }
    return max_num;
}
 
int sum()
{
    int sum = 0;
    for (int i = max_num; i <= 16; i++)
    {
        sum += arr[i];
    }
    return sum;
}
 
void sort()
{
    int buffer = 0;
    for (int i = 0; i < 16; i++)
    {
        if (arr[i] > arr[i + 1])
        {
            buffer = arr[i];
            arr[i] = arr[i + 1];
            arr[i + 1] = buffer;
        }
    }
}
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(LC_ALL, "");
    for (int i = 15; i >= 0; i--)
    {
        arr[i] = i * 5;
    }
    cout << "Сумма:" << sum() << endl;
    cout << "Максимальное значение:" << max_el << endl;
    for (int i = 0; i < 16; i++)
    {
        cout << "Элемент под номером " << i << " равен " << arr[i] << endl;
    }
    system("pause");
    return 0;
}
Бросил ятут код исобрал (не без помощи) более простой код. главный момент нужно там по заданию с модулем посчитать но не как не догоню как пользоваться функцией abs labs
IIapa3uT
0 / 0 / 0
Регистрация: 07.02.2016
Сообщений: 25
09.02.2016, 01:26  [ТС] #6
Спасибо!
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
09.02.2016, 01:26
Привет! Вот еще темы с ответами:

Объяснить и подробно прокомментировать, что происходит в коде (программа по поразрядным операциям) - C++
помогите разобраться в программе вот задание (Первые 15 наиболее часто встречающихся символов кодируются 4-битными кодами от 0000 до 1110....

Объяснить фрагмент кода - C++
Добрый день, господа. Есть у меня такая вот задачка - надо объяснить структуру фрагмента. По сути, погадать по единственной строчке кода....

Объяснить и прокомментировать каждую строку кода - C++
Добрый вечер нуждаюсь в комментариях к программе , желательно прокомментировать каждую строку. #include &quot;stdafx.h&quot; #include...

Подробно объяснить код шаблонной функции, вычисляющей размер массива во время компиляции - C++
template &lt;typename T, size_t N&gt; size_t ArraySize(const T (&amp;)) { return N; } объясните что здесь происходит. из всего этого...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
09.02.2016, 01:26
Ответ Создать тему
Опции темы

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