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

Считать 100 элементов под случайными индексами в списке

20.02.2022, 20:34. Показов 342. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер. Нужно сравнить скорость динамического массива и односвязного списка, считывая 100 элементов. Если с динамическим массивом я как-то разобрался (хотя я сомневаюсь, что это правильно), то как сделать это со списком - понять не могу. Помогите, пожалуйста.
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
#include <iostream>
#include<string>
#include <time.h>
 
using namespace std;
 
 
struct DynamicArray
{
    int counter = 0;
public:
    int size;
    int * arr;
    DynamicArray(int size_)
    {
        size = size_;
        arr = new int[size];
    }
 
 
    void Push_front(int value)
    {
        int* newArr = new int[size + 1];
        for (int j = 0, i = 1; j < size; j++, i++)
            newArr[i] = arr[j];
 
        newArr[0] = value;
        delete[] arr;
        size++;
        arr = newArr;
    }
 
    ~DynamicArray()
    {
        delete[] arr;
    }
};
 
struct LinkedList {
    struct Node {
 
        int val;
        Node* next;
 
        Node(int _val) : val(_val), next(nullptr) {}
    };
    Node* first;
    Node* last;
    int len = 0;
    LinkedList() : first(nullptr), last(nullptr) {}
 
    bool is_empty() {
        return first == nullptr;
    }
 
 
    void push_front(int key)
    {
        Node* node = new Node(key);
        node->val = key;
        node->next = first;
        first = node;
        len++;
    }
    void print() {
        if (is_empty()) return;
        Node* p = first;
        while (p) {
            cout << p->val << " ";
            p = p->next;
        }
        cout << endl;
    }
};
 
int main()
{
    srand(time(NULL));
    int size = 100;
 
 
    clock_t start = clock();
    DynamicArray arr(size);
    for (int i = 0; i < size; i++)
    {
        arr.Push_front(i);
    }
    for (int i = 0; i < size; i++)
        cout << arr.arr[rand() % size] << " ";
    clock_t end = clock();
    double seconds = (double(end - start)) / CLOCKS_PER_SEC;
    cout << "\n\nDynamic array:  " << seconds << " seconds.";
 
 
    LinkedList l;
    for (int i = 0; i < size; i++)
    {
        l.push_front(i);
    }
    for (int i = 0; i < size; i++)
       //???
    return 0;
}
Добавлено через 2 минуты
Если надо, то вот функция вывода для массива
C++
1
2
3
4
5
    void Print()
    {
        for (int i = 0; i < size; i++)
            cout << arr[i] << " ";
    }
А вот для списка
C++
1
2
3
4
5
6
7
8
9
void print() {
        if (is_empty()) return;
        Node* p = first;
        while (p) {
            cout << p->val << " ";
            p = p->next;
        }
        cout << endl;
    }
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.02.2022, 20:34
Ответы с готовыми решениями:

Подсчет суммы элементов массива с нечетными индексами -100.100
Подсчет суммы элементов массива с нечетными индексами -100...100 Используется Button, ListBox Помоите пожалуйста подробно

Заполнить массив состоящий из N элементов случайными числами в интервале от -100 до 100
Как заполнить массив состоящий из N элементов случайными числами в интервале от -100 до 100. В результате должен получиться возрастающий...

Заполнить массив из 100 элементов случайными целыми числами в диапазоне от 1 до 100
Мне очень нужна помощь, надеюсь откликнетесь... помогите написать, пожалуйста! 1. Заполнить массив из 100 элементов случайными целыми...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
20.02.2022, 20:34
Помогаю со студенческими работами здесь

Заполнить массив из 20 элементов случайными числами в интервале [-100;100]. Найти минимальное значение и сумму чисел
Заполнить массив из 20 элементов случайными числами в интервале . Найти минимальное значение и сумму чисел.

Найти количество отрицательных чисел, одномерного массива размером 30 элементов, заполненного случайными числами из отрезка [-100;100]
Всем привет, нужна помощь с решением задачи. 2) Найдите количество отрицательных чисел, одномерного массива размером 30 элементов,...

Заполнить массив h(6) случайными значениями. Найти сумму элементов массива с четными индексами
(Дан массив h(6) . Заполнить массив h(6) случайными значениями. Найти сумму элементов массива с четными индексами, вывести массив на...

Напишите программу, которая заполняет массив из 30 элементов случайными числами в диапазоне от 0 до 100, и выводит значения элементов массива на экран
2. Напишите программу, которая заполняет массив из 30 элементов случайными числами в диапазоне от 0 до 100, и выводит значения элементов...

Заполнить массив из 100 элементов случайными числами от 100 до 300. Вывести массив. Вывести числа массива без повторо
Как это сделать через одновременные массивы?


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 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. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru