Форум программистов, компьютерный форум CyberForum.ru

Создайте динамический массив указателей на структуры - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Произвести шифрование с использованием поразрядной операции «исключающее или» http://www.cyberforum.ru/cpp-beginners/thread683576.html
Помогите пожалуйста с задачкой! Считать две строки: «текст» и «ключ». Произвести шифрование с использованием поразрядной операции «исключающее или». Вывести посимвольно результат (зашифрованный текст). Произвести повторное XOR-гаммирование зашифрованного ранее текста и вывести полученную строку (чтобы видеть, что она совпадает с исходным текстом). Необходимо реализовать XOR-гаммирование в...
C++ Создать текстовой редактор, который способен находить в тексте слово Создать тестовой редактор который был бы способен находить в тексте интересующее слово и указывать номер строки в которой оно расположено.Также эта программа должна подсчитовать количество строк в тексте и кол-во слов. http://www.cyberforum.ru/cpp-beginners/thread683543.html
C++ О, этот Visual Studio
Проблема на скрине #include <stdio.h> #include <time.h> #include <stdlib.h> #define X 10 #define Y 10 int main() {
C++ Отображение файла в оперативную память
Реализовать отображение файла в оперативную память. Выполнить задание, с использованием этого отображения. Задание: Создать массив N элементов и отсортировать его элементы в порядке возрастания с помощью метода «пузырь». Элементы массива сгенерировать случайным образом с помощью встроенных функций. Результирующий массив вывести во внешний файл через отражение файла в оперативной памяти. ...
C++ Написать функцию, определяющую, является ли число "счастливым" http://www.cyberforum.ru/cpp-beginners/thread683522.html
1. Назовём четырёхзначное число счастливым, если произведение цифр этого числа равно их сумме. Например, число 2114 – счастливое, поскольку 2+1+1+4 = 2*1*1*4 = 8. Напишите функцию, которая принимает черырёхзначное число в качестве аргумента и возвращает true, если оно – счастливое, и false – нет. Используя данную функцию, выведите на экран все счастливые числа из диапазона от 1000 до 9999.
C++ Калькулятор периметра, объема, площади. Оптимизация =) Вот, составил калькулятор вычисляющий периметр круга, объем шара, площадь и объем цилиндра... Все работает, но хотелось бы оптимизировать)) Код: #include <iostream> using namespace std; int main(void) { int r, h; float p, v, s, v2; подробнее

Показать сообщение отдельно
Ded_Vasilij
 Аватар для Ded_Vasilij
229 / 211 / 15
Регистрация: 01.09.2012
Сообщений: 2,103
29.10.2012, 18:41     Создайте динамический массив указателей на структуры
Задача:
дана структура
C++
1
2
3
4
5
6
struct Sample
{
    char c;
    double x;
    int *p;
};
Создайте динамический массив указателей на структуры типа Sample. Выделите каждому указателю массива память под одну структуру.
Сделайте так, чтобы поле p каждой структуры указывал на начало массива из n элементов (число n вводится с клавиатуры). Для i-го элемента массива структур инициализируйте элементы элементы массива p числом i. Распечатайте все структуры.

Пока чего - то вариантов нет. Точнее говоря просто создать динамический массив структур я могу и распечатать его тоже.
вот код:
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
void f5()
{
    int n;
    cin >> n;
    Sample *st = 0;
    try
    {
        st = new Sample[n];
    }
    catch (bad_alloc e)
    {
        cerr << e.what();      
    }
    for (int i = 0; i < n; i++)
    {
            st[i].p = 0;
    }  
 
    try {
        for (int i = 0; i < n; i++)
        {
            st[i].p = new int[n];
 
            for (int j = 0; j < n; j++)
            {
                st[i].p[j] = i;
            }
            st[i].c = 'F';
            st[i].x = i + 5;
        }
    }
    catch (bad_alloc e)
    {
        for (int i = 0; i < n; i++)
        {
            delete[] (st[i].p);
        }
        delete[](st);
        cerr << e.what();
        return;
    }
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            cout << st[i].p[j] << ' ' ;
        }
        cout << endl;
        cout << "st[" << i << "].c = " << st[i].c << endl;
        cout << "st[" << i << "].x = " << st[i].x << endl;
        cout << ' ' << endl;
        delete[](st[i].p);
    }
    delete[] (st);
}
А вот как решить эту задачу не знаю. Не могу просто на картинке представить как это будет выглядеть. Подскажите если не сложно.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 02:37. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru