Форум программистов, компьютерный форум, киберфорум
C (Си)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 09.04.2020
Сообщений: 2

Обработка массивов

31.03.2022, 02:57. Показов 650. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пишу программу создающую массивы заданной длинны и проводящая над ними манипуляции. Использовать другие библиотеки нельзя.
Сначала формируется массив М1 длинны N, после чего формируется массив M2 длинны N/2. В массиве М1 к каждому элементу применяется операция деление на Пи с последующим возведением в третью степень. Затем в массиве М2 каждый элемент поочерёдно складывается с предыдущим, а к результату сложения применяется операция модуль тангенса. После чего ко всем элементам массива М1 и М2 с одинаковыми индексами применяется возведение в степень и полученный массив сортируется гномьей сортировкой. И в конце считается сумма синусов элементов массива М2, которые при делении на минимальный ненулевой элемент массива М2 дают чётное число.
Проблема в том, что результат X выдает -nan. Никак не могу понять где именно ошибка.

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
101
102
#include <stdio.h>
#include <math.h>
#include <stdlib.h>
 
const int A = 441;
const double PI = 3.1415926535897931159979635;
 
inline void dwarf_sort(double* array, int size) {
    size_t i = 1;
    while (i < size) {
        if (i == 0) {
            i = 1;
        }
        if (array[i - 1] <= array[i]) {
            ++i;
        }
        else
        {
            long tmp = array[i];
            array[i] = array[i - 1];
            array[i - 1] = tmp;
            --i;
        }
    }
}
 
inline double reduce(double* array, int size) {
 
    size_t i;
    double min = RAND_MAX, sum = 0;
 
    for (i = 0; i < size; ++i) {
        if (array[i] < min && array[i] != 0) {
            min = array[i];
        }
    }
 
    for (i = 0; i < size; ++i) {
        if ((int)(array[i] / min) % 2 == 0) {
            sum += sin(array[i]);
        }
    }
    return sum;
}
 
int main(int argc, char* argv[])
{
    int i, N, j;
    double* M1 = NULL, * M2 = NULL, * M2_copy = NULL;
    double X;
    unsigned int seed = 0;
 
    N = atoi(argv[1]); /* N равен первому параметру командной строки */
    M1 = malloc(N * sizeof(double));
    M2 = malloc(N / 2 * sizeof(double));
    M2_copy = malloc(N / 2 * sizeof(double));
 
    for (i = 0; i < 100; i++) 
    {
        seed = i;
        srand(i); 
        
        /*generate*/
        for (j = 0; j < N; ++j) {
            M1[j] = (rand_r(&seed) % A) + 1;
        }
 
        for (j = 0; j < N / 2; ++j) {
            M2[j] = (rand_r(&seed) % (10 * A)) + 1;
        }
 
        /*map*/
        for (j = 0; j < N; ++j)
        {
            M1[j] = pow(M1[j] / PI, 3);
        }
 
        for (j = 0; j < N / 2; ++j) {
            M2_copy[j] = M2[j];
        }
 
        M2[0] = fabs(tan(M2_copy[0]));
        for (j = 0; j < N / 2; ++j) {
            M2[j] = fabs(tan(M2[j] + M2_copy[j]));
        }
 
        /*merge*/
        for (j = 0; j < N / 2; ++j) {
            M2[j] = pow(M1[j], M2[j]);
        }
 
        /*sort*/
        dwarf_sort(M2, N / 2);
 
        /*sort*/
        X = reduce(M2, N / 2);
    }
    
    printf("\nN=%d.\n", N); 
    printf("X=%f\n", X);
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
31.03.2022, 02:57
Ответы с готовыми решениями:

Обработка массивов
Требуется написать программу, которая вычисляет сумму всех положительных элементов массива. Массив и его длина вводятся пользователем и вот...

Обработка динамических массивов
Непосредственно задание: В матрице размером NxM упорядочить элементы столбцов, содержащих нулевые элементы, по возрастанию методом простой...

Обработка массивов структурированных данных
Добрый день! Помогите пожалуйста... Я только учусь... Мне надо написать программу... пока есть только меню... а надо что бы каждый пункт...

3
из племени тумба-юбма
 Аватар для мама Стифлера
2523 / 1819 / 419
Регистрация: 29.11.2015
Сообщений: 8,857
Записей в блоге: 15
01.04.2022, 23:51
Ваш код не компилируется, что то с функцией rand() намудрили.
0
0 / 0 / 0
Регистрация: 09.04.2020
Сообщений: 2
02.04.2022, 01:28  [ТС]
Пользуюсь GCC на linux и все компилируется. В данном случае мне нужен rand_r() для работы программы с несколькими процессами. Чтобы запустить например в visual studio можно поменять rand_r() на rand().
0
из племени тумба-юбма
 Аватар для мама Стифлера
2523 / 1819 / 419
Регистрация: 29.11.2015
Сообщений: 8,857
Записей в блоге: 15
02.04.2022, 09:13
Dagi, даже если заменить на rand(), то такое тоже не компилируется.
Вот что это за параметр в скобках - rand(&seed) - у меня не компилируется
Если написать так - rand() - тогда компилируется
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.04.2022, 09:13
Помогаю со студенческими работами здесь

Обработка чисел без массивов
Задание: Дано целое десятичное число &quot;a&quot;.Заменить в представления числа &quot;а&quot; цифры 6 и 7 нулями. С числами типа: 156789762 работает...

Обработка двухмерных массивов с использованием функций
Каждый пункт нижеприведенного задания оформить в виде функции. Все необходимые данные для функций должны передаваться им в качестве...

Обработка двухмерных массивов с использованием функций
Каждый пункт нижеприведенного задания оформить в виде функции. Все необходимые данные для функций должны передаваться им в качестве...

Обработка массивов данных. Указатели. Динамическое распределение памяти
Помогите написать коды на си 1.Найти максимальный по модулю элемент массива. 2. Найти сумму элементов массива, расположенных между...

Обработка одномерных массивов, поиск минимального и максимального, и их сложение
В решении задачи предпочтительнее использовать динамические массивы, во всех случаях когда длина заранее не известна. Выводить на экран...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
1С: Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью. Данные берутся из регистра сведений, по которому настроено. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru