Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 2
Регистрация: 07.02.2016
Сообщений: 25

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

07.02.2016, 22:52. Показов 997. Ответов 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;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.02.2016, 22:52
Ответы с готовыми решениями:

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

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

Объяснить и подробно прокомментировать, что происходит в коде (циклы и массивы)
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++) ...

5
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
08.02.2016, 12:04
Цитата Сообщение от IIapa3uT Посмотреть сообщение
Меня интересуют именно те строки которые выше (int _tmain)
Ну, там строк довольно много, около 60-ти. Какие именно непонятны?
1
:)
Эксперт С++
4773 / 3267 / 497
Регистрация: 19.02.2013
Сообщений: 9,046
08.02.2016, 13:02
Цитата Сообщение от IIapa3uT Посмотреть сообщение
number_within_the_limmmits
Код заика писал что ли?
Цитата Сообщение от IIapa3uT Посмотреть сообщение
Изучаю C++ 2 дня.
Цитата Сообщение от IIapa3uT Посмотреть сообщение
массивы и работа с ними для меня глухой лес.
Надо просто ещё почитать немного литературы.
1
 Аватар для Storm Screamer
4898 / 1464 / 117
Регистрация: 21.04.2013
Сообщений: 8,777
08.02.2016, 13:42
Цитата Сообщение от IIapa3uT Посмотреть сообщение
Данную задачу нашел на просторах интернета.
На начальных этапах обучения копировать чужой код - ошибка. Как итог ничего не поймешь и не разберешься, особенно без теоретической части.
0
0 / 0 / 2
Регистрация: 07.02.2016
Сообщений: 25
09.02.2016, 01:16  [ТС]
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
0
0 / 0 / 2
Регистрация: 07.02.2016
Сообщений: 25
09.02.2016, 01:26  [ТС]
Спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.02.2016, 01:26
Помогаю со студенческими работами здесь

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

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

Объяснить и подробно прокомментировать, что происходит в коде
Помогите написать комментарии к каждой строке кода,желательно чтоб было объяснение,что именно происходить в строке #include...

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

Подробно объяснить строку кода
:help: :help: :help: Кто-нибудь, объясните ПОСИМВОЛЬНО, пожалуйста, как ЭТА ЕРЕСЬ работает? Что это за сокращенный сатанинский обряд? ...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru