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

Добавление чисел Фибоначчи в начало динамического массива

10.01.2020, 22:02. Показов 1300. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток, товарищи программисты.

В общем, нужно с помощью calloс создать одномерный массив, затем заполнить его рандомными числами, а после добавить в начало этого массива введенное с клавиатуры кол-во чисел Фибоначчи.
Я написал код, но при больших значениях программа вылетает, в чём ошибка и что вы вообще посоветуете подкорректировать?

И оцените сам код, дайте максимально конструктивную критику : что я использую не так, что вообще не нужно использовать...
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
#include <iostream>
#include <cstdlib>
#include <ctime>
 
using namespace std;
void FillArray(int *array,int size);
void OutArray(int *array,int size);
int Fib(int amount);
 
int main()
{
    srand(time(NULL));
    int size = 0, amount = 0;
    int* first = 0;
    cout << "Enter size : ";
    cin >> size;
    first = (int*) calloc(size, sizeof(int));
    FillArray(first, size);
    OutArray(first, size);
    cout << "How many Fib's number do you want to add : ";
    cin >> amount;
    int n_s = amount + size;
// size = 3, n_s = 7;
    first = (int*) realloc(first,n_s * sizeof(int));
    if(first == NULL){
        cout << "Memory is not available!" << endl;
        free(first);
    }
        for(int a = n_s, i = 0, j = size; i <= size; i++, j--, a--){
            *(first + a)=*(first+j);
            *(first+j) = 0;
        }
 
        for(int i = 0; i < amount; i++){
            *(first+i) = Fib(i);
        }
    OutArray(first, n_s);
    int count  = 0;
    free(first);
    first = NULL;
}
 
void FillArray(int *array,int size){
    for(int i = 0; i < size; i++){
        *(array + i ) = rand() % 100;
    }
}
 
void OutArray(int *array,int size){
    for(int i = 0; i < size; i++){
        cout << *(array + i) << " ";
    }
    cout << endl;
}
 
int Fib(int amount){
    if(amount == 0)
        return 0;
    if(amount == 1)
        return 1;
    else
        return Fib(amount - 1 ) + Fib(amount - 2);
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.01.2020, 22:02
Ответы с готовыми решениями:

Добавление элемента в начало динамического массива
Господа подскажите пожалуйста ошибку в коде. Не верно работает добавление нового элемента в начало динамического массива. Не могу допетрить...

Генерирование чисел Фибоначчи посредством динамического программирования с С++ на Python
Помогите перевести программу с C++ на Python , условия задачи у меня было( Генерирование чисел Фибоначчи посредством динамического...

Добавить элементы в начало динамического массива
Доброго дня,мне нужна помощь с задачей по динамичным массивам. Суть задания:для начала нужно сформировать динамичный массив и заполнить...

3
653 / 466 / 183
Регистрация: 23.04.2019
Сообщений: 1,987
11.01.2020, 00:06
calloc, malloc, хренлок - си
Идите лучше на раздел Си для начинающих
0
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
11.01.2020, 11:02
Цитата Сообщение от yyossemite Посмотреть сообщение
if(first == NULL){
        cout << "Memory is not available!" << endl;
        free(first); // ОШИБКА!!! Что ты освобождаешь?
    }
Строки 29-32 Переписывать надо начиная с конца. Иначе можно затереть нужноею
Строки 56-63 Считать так числа Фибоначчи - великий грех!
0
0 / 0 / 0
Регистрация: 10.01.2020
Сообщений: 2
11.01.2020, 22:32  [ТС]
Спасибо. А как лучше тогда считать числа Фибоначчи?

И не совсем понял о строках 29-32, можно немного подробнее?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.01.2020, 22:32
Помогаю со студенческими работами здесь

Добавление и удаление элемента динамического массива
Подскажите какие существую способы добавления и удалеия элемента одномерного динамического массива(переопределяя размер массива)....

Добавление элемента в конец динамического массива!
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;malloc.h&gt; using namespace std; int main() { int i, key, n, amountRem,...

Добавление элемента в конец динамического массива
Не понимаю почему у меня не выходит данный код (еще только учусь) void pushBack(int* arr, int* size, int value) { int *nwArr =...

Добавление К элементов в начало массива
Есть такой код #include &lt;vcl.h&gt; #pragma hdrstop #include &lt;conio.h&gt; #include &lt;stdlib.h&gt; #include &lt;iostream.h&gt; #define MSIZE...

Добавление элементов в начало массива
Нужно добавить некоторое количество элементов в начало массива. Проблема заключается в том, что в результате лезет мусор. Я так...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru