Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/18: Рейтинг темы: голосов - 18, средняя оценка - 4.83
0 / 0 / 0
Регистрация: 02.10.2018
Сообщений: 1

Обработка последовательности чисел

02.10.2018, 21:54. Показов 3476. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Напишите программу, выделив каждую подзадачу в отдельную функцию.

Реализуйте программу, на вход которой подается одно из значений 0, 1, 2, 3 и массив целых чисел размера не больше 100. Числа разделены пробелами. Строка заканчивается символом перевода строки.

В зависимости от значения, функция должна выводить следующее:

0 : индекс первого нулевого элемента. (index_first_zero)
1 : индекс последнего нулевого элемента. (index_last_zero)
2 : Найти сумму модулей элементов массива, расположенных от первого нулевого элемента и до последнего. (sum_between)
3 : Найти сумму модулей элементов массива, расположенных до первого нулевого элемента и после последнего. (sum_before_and_after)


иначе необходимо вывести строку "Данные некорректны".

Ошибкой в данном задании считается дублирование кода!

Подсказка: функция нахождения модуля числа находится в заголовочном файле stdlib.h стандартной библиотеки языка Си.
При выводе результата, не забудьте символ переноса строки
Sample Input:

0 -21 10 0 -23 -7 -15 -14 8 -9 10 -13 -14 -27 0 -7 12 -18
Sample Output:

2
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.10.2018, 21:54
Ответы с готовыми решениями:

В последовательности целых чисел найти количество чисел в которых нет 3 и 7 и наименьшее среди этих чисел
Разработать процедуру, которая в последовательности целых чисел находит количество чисел в которых нет 3-ки и 7-ки и наименьшее среди этих...

В последовательности чисел найти количество преобразованных по правилу 1 чисел и наименьшее среди этих чисел
Использование нескольких функций Разработать процедуру, которая в последовательности целых чисел находит количество преобразованных по...

Как из последовательности 20 чисел вычислить сумму нечетных чисел и определить количество четных чисел.
Помогите пожалуйста !!!! Из последовательности 20 чисел вычислить сумму нечетных чисел и определить количество четных чисел.

1
74 / 50 / 29
Регистрация: 30.08.2012
Сообщений: 143
03.10.2018, 03: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
#include <stdio.h>
#include <stdlib.h>
 
#define MAXSTR (2048)
 
void task(int action, int *arr, int n)
{
    int index_first_zero = -1;
    int index_last_zero = -1;
    int sum_between = 0;
    int sum_before_and_after = 0;
    int i, sum = 0;
    for (i = 0; i < n; ++i)
    {
        if (arr[i] == 0)
        {
            if (index_first_zero == -1)
            {
                index_first_zero = i;
                sum_before_and_after = sum, sum = 0;
            }
            else sum_between += sum, sum = 0;
            index_last_zero = i;
        }
        sum += abs(arr[i]);
    }
    sum_before_and_after += sum;
 
    if (index_last_zero != -1 && action >= 0 && action <= 3)
    {
        switch (action)
        {
        case 0:
            printf("%d\n", index_first_zero);
            break;
        case 1:
            printf("%d\n", index_last_zero);
            break;
        case 2:
            printf("%d\n", sum_between);
            break;
        case 3:
            printf("%d\n", sum_before_and_after);
            break;
        }
    }
    else printf("Invalid data\n");
}
 
int main()
{
    char buffer[MAXSTR], *ptr, *prev_ptr = buffer;
    int action, arr[102], n;
    fgets(buffer, MAXSTR, stdin);
    action = strtol(prev_ptr, &ptr, 10);
    for (n = 0; prev_ptr != ptr; ++n)
        arr[n] = strtol(prev_ptr = ptr, &ptr, 10);
    task(action, arr, --n);
    system("pause");
    return 0;
}


Если нет, то могу предложить такой вариант.
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
#include <stdio.h>
#include <stdlib.h>
 
#define MAXSTR (2048)
 
void task(int action, int *arr, int n)
{
    int x[] = { -1, -1, 0, 0 }, i, sum = 0;
    for (i = 0; i < n; ++i)
    {
        if (arr[i] == 0)
        {
            if (x[0] == -1) x[0] = i, x[3] = sum;
            else x[2] += sum;
            sum = 0;
            x[1] = i;
        }
        sum += abs(arr[i]);
    }
    x[3] += sum;
    if (x[1] != -1 && action >= 0 && action <= 3) printf("%d\n", x[action]);
    else printf("Invalid data\n");
}
 
int main()
{
    char buffer[MAXSTR], *ptr, *prev_ptr = buffer;
    int action, arr[102], n;
    fgets(buffer, MAXSTR, stdin);
    action = strtol(prev_ptr, &ptr, 10);
    for (n = 0; prev_ptr != ptr; ++n) arr[n] = strtol(prev_ptr = ptr, &ptr, 10);
    task(action, arr, --n);
    system("pause");
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.10.2018, 03:55
Помогаю со студенческими работами здесь

Задано N количество чисел последовательности и последовательность из N чисел. Найти и вывести произведение этих чисел и первое положительно число
Задано N количество чисел последовательности и последовательность из N чисел. Найти и вывести произведение этих чисел и первое положительно...

Подсчитать количество отрицательных чисел во введенной последовательности. Конец последовательности-число 0
Подсчитать количество отрицательных чисел во введенной последовательности. Конец последовательности-число 0. НА PHP ИСПОЛЬЗОВАТЬ...

Подсчитать количество отрицательных чисел во введенной последовательности. Конец последовательности-число 0
В документе создайте форму, в которой пользователь введет данные, необходимые для решения задачи, и кнопки типа Submit для активизации ...

подсчитать количество отрицательных чисел во веденной последовательности , Конец последовательности число 0
&lt;meta charset = &quot;utf-8&quot;&gt; &lt;form method = &quot;post&quot;&gt; подсчитать количество отрицательных чисел во веденной последовательности , ...

В последовательности из n целых чисел все элементы уменьшить на минимальное число последовательности
Помогите, пожалуйста! Разработать и написать алгоритм указанной задачи. В последовательности из n целых чисел все элементы уменьшить на...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Модель заражения группы наркоманов
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