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

Необработанное исключение по адресу 0x00007FFC1E08AFEC (ucrtbased.dll) в lab work 4.exe: Недопустимый параметр был

26.12.2022, 15:57. Показов 809. Ответов 1

Студворк — интернет-сервис помощи студентам
передан функции, для которой недопустимые параметры вызывают неустранимую ошибку.

Объясните, пожалуйста, какая ошибка в коде? Задача заключается в реализации комбинированного алгоритма, в котором быстрый рекурсивный переключается на традиционный при n<n0. Проверить работоспособность и корректность реализации на контрольном примере небольшой размерности.

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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
#include <algorithm>
#include <cstdio>
#include <ctime>
#include <vector>
#include <complex>
#include <iostream>
#define M_PI 3.14159265
 
using namespace std;
 
typedef complex<double> cd;
typedef vector<cd> vcd;
 
vcd traditional(const vcd& as)
{
    int n = as.size();
    if (n == 1) return vcd(1, as[0]);
    vcd w(n);
    for (int i = 0; i < n; i++) 
    {
        double alpha = 2 * M_PI * i / n;
        w[i] = cd(cos(alpha), sin(alpha));
    }
    vcd A(n / 2), B(n / 2);
    for (int i = 0; i < n / 2; i++) 
    {
        A[i] = as[i * 2];
        B[i] = as[i * 2 + 1];
    }
    vcd Av = traditional(A);
    vcd Bv = traditional(B);
    vcd res(n);
    for (int i = 0; i < n; i++)
        res[i] = Av[i % (n / 2)] + w[i] * Bv[i % (n / 2)];
    return res;
}
 
vcd FFT(const vcd& as)
{
    int n = as.size();
    int k = 0; 
    while ((1 << k) < n) k++;
    vector<int> rev(n);
    rev[0] = 0; int high1 = -1;
    for (int i = 1; i < n; i++) {
        if ((i & (i - 1)) == 0) 
            high1++;
        rev[i] = rev[i ^ (1 << high1)]; 
        rev[i] |= (1 << (k - high1 - 1)); 
    }
    vcd roots(n);
    for (int i = 0; i < n; i++) {
        double alpha = 2 * M_PI * i / n;
        roots[i] = cd(cos(alpha), sin(alpha));
    }
    vcd cur(n);
    for (int i = 0; i < n; i++)
        cur[i] = as[rev[i]];
    for (int len = 1; len < n; len <<= 1) {
        vcd ncur(n);
        int rstep = roots.size() / (len * 2);
 
        for (int pdest = 0; pdest < n;) {
            int p1 = pdest;
            for (int i = 0; i < len; i++) {
                cd val = roots[i * rstep] * cur[p1 + len];
                ncur[pdest] = cur[p1] + val;
                ncur[pdest + len] = cur[p1] - val;
                pdest++, p1++;
            }
            pdest += len;
        }
        cur.swap(ncur);
    }
    return cur;
}
 
void combo(int n, int n0, double kof, vcd as, clock_t stime) 
{
    cout << "\n Combined method :\n";
    stime = clock();
    for (int i = 0; i <= 100; i++)
    {
        stime = clock();
        if (n >= n0)
        {
            vcd res = FFT(as);
        }
        else if (n < n0)
        {
            vcd res2 = traditional(as);
        }
        kof += (clock() - stime);
    }
    kof = kof / 100;
    cout << "Time (in ms.) :" << kof << endl;
    kof = 0;
    for (int i = 0; i < n; i++)
    {
        if (i >= n0)
        {
            vcd res = FFT(as);
            printf("%.4lf %.4lf\n", res[i].real(), res[i].imag());
        }
        else if (i <= n0)
        {
            vcd res2 = traditional(as);
            printf("%.4lf %.4lf\n", res2[i].real(), res2[i].imag());
        }
    }
}
 
int main()
{
    int n;
    int n0 = 0;
    double kof = 0;
    cout << "Enter dimension: ";
    cin >> n;
    vcd as(n);
    for (int i = 0; i < n; i++) 
    {
        as[i] = rand() % 10;
        cout << "X" << i + 1 << " = " << as[i] << endl;
    }
    cout << "\n FFT algorithm: \n";
    clock_t stime = clock();
    for (int i = 0; i <= 100; i++)
    {
        stime = clock();
        vcd res = FFT(as);
        kof += (clock() - stime);
    }
    kof = kof / 100;
    cout << "Time (in ms.) :" << kof << endl;
    kof = 0;
    vcd res = FFT(as);
    for (int i = 0; i < n; i++)
        printf("%.4lf %.4lf\n", res[i].real(), res[i].imag());
    cout << "\n Traditional algorithm: \n";
    for (int i = 0; i <= 100; i++)
    {
        stime = clock();
        vcd res2 = traditional(as);
        kof += (clock() - stime);
    }
    kof = kof / 100;
    cout << "Time (in ms.) :" << kof << endl;
    kof = 0;
    vcd res2 = traditional(as);
    for (int i = 0; i < n; i++)
        printf("%.4lf %.4lf\n", res2[i].real(), res2[i].imag());
    combo(n, n0, kof, as, stime);
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.12.2022, 15:57
Ответы с готовыми решениями:

Необработанное исключение по адресу 0x576CF2F6 (ucrtbased.dll) в Курсовая 4.exe: Недопустимый параметр был передан функц
Добрый день, умоляю помогите, я вообще не понимаю почему не работает. Весь код скопировал с примера и все равно. #define...

Необработанное исключение по адресу 0x7B93F2F6 (ucrtbased.dll) в Laba_5.exe: Недопустимый параметр был передан функции,
Пишу код-вводится строка из слов, которые разделены пробелами , в слове нужно найти символ, а затем подсчитать количество слов с этим...

Необработанное исключение по адресу 0x0FFCE906. Недопустимый параметр был передан функции
В Binar.cpp появляется необработанное исключение. Подскажите, как это исправить, пожалуйста. Head.cpp #include &lt;iostream&gt; ...

1
79 / 60 / 22
Регистрация: 14.12.2022
Сообщений: 240
26.12.2022, 16:38
при размерности пять ошибка в коде:
C++
1
2
 for (int i = 0; i < n; i++)
    cur[i] = as[rev[i]];
rev[3] == 6 что есть выход за пределы вектора as;
А вообще осваивай дебаггер
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
26.12.2022, 16:38
Помогаю со студенческими работами здесь

Необработанное исключение по адресу 0x7A97DB1B (ucrtbased.dll) в ConsoleApplication15.exe: 0xC0000005
Необработанное исключение по адресу 0x7A97DB1B (ucrtbased.dll) в ConsoleApplication15.exe: 0xC0000005: нарушение прав доступа при чтении по...

Необработанное исключение по адресу 0x7B45DB1B (ucrtbased.dll) в ConsoleApplication20.exe: 0xC0000005
Добрый день, подскажите пожалуйста в чем проблема? Не могу понять в чём проблема.. Необработанное исключение по адресу 0x7B45DB1B...

Необработанное исключение по адресу 0x0FF3C6BC (ucrtbased.dll) в lab4.exe: 0xC0000005: нарушение прав доступа при запис
// Дана ведомость абитуриентов. В каждой строке записана фамилия абитуриента, // средний балл аттестата. Определить средний балл...

Необработанное исключение по адресу 0x688BFC66 (ucrtbased.dll) в ConsoleApplication10.exe: Недопустимый
я пытался создать функцию возвращающая массив из строк созданный из 1 строки разделенной по знаку но у меня вылезло исключение...

Необработанное исключение по адресу 0x7C5101C9 (ucrtbased.dll) в EXAM.exe: 0xC0000005: нарушение прав доступа при записи
Доброго времени суток. Необходимо переписать данные структуры в файл и после прочитать. Не могу понять, где допустила ошибку, при...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru