Главная » Просмотр файлов » часть ответов на вопросы

часть ответов на вопросы (1161210)

Файл №1161210 часть ответов на вопросы (Решённые задачи прошлых лет)часть ответов на вопросы (1161210)2019-09-19СтудИзба
Просмтор этого файла доступен только зарегистрированным пользователям. Но у нас супер быстрая регистрация: достаточно только электронной почты!

Текст из файла

6. Ниже приведена спецификация родового пакета Stacks на языке Ада.

Напишите объявление шаблонного класса на языке Си++, предназначенного

для той же роли, что и этот пакет.

GENERIC

TYPE T IS PRIVATE; SIZE : INTEGER;

PACKAGE Stacks IS

TYPE Stack IS LIMITED PRIVATE;

PROCEDURE Push(S: IN OUT Stack; X : IN T);

PROCEDURE Pop(S: IN OUT Stack; X : OUT T);

FUNCTION IsEmpty(S : IN Stack) RETURN BOOLEAN;

FUNCTION IsFull(S : IN Stack) RETURN BOOLEAN;

PRIVATE

TYPE Stack is RECORD

Body : ARRAY (1..SIZE) OF T;

Top : INTEGER := 1;

END RECORD;

END Stacks;

Один из вариантов:

template <typename T, int size> class Stack

{

public:

Stack() {top = 0;}

void Push(T x);

T Pop(T& x);

bool IsEmpty();

bool IsFull();

private:

Stack (const Stack& s);

T body[N];

int top;

};

8. Напишите на языке Ада 95 объявления, эквивалентные

приведенным ниже описаниям на языке Оберон-2.

TYPE T* = RECORD I*, J : INTEGER; END;

TYPE T1* = RECORD (T) K : INTEGER; END;

PROCEDURE (VAR X: T) P* (L : INTEGER);

PROCEDURE (VAR X: T1) P* (L : INTEGER);

Полностью эквивалентный фрагмент написать нельзя, поскольку Ада

требует полной инкапсуляции структуры типа, а Оберон позволяет открывать

поля структуры (в примере - I открыто, а J – закрыто). Однако можно на Аде

написать написать подпрограммы доступа для I (get/set) и добиться того же

эффекта.

type T is tagged private;

type T1 is new tagged T with private;

procedure P(X:T; L: integer);

procedure P(X:T1; L: integer);

Замечание: на языке Оберон процедуры P динамически привязаны к

типу (T и T1 соответственно), однако на Аде динамическая привязка — это

свойство не метода, а вызова. Поэтому разницы между динамически и

статическими привязанными методами в Аде нет.

3. Напишите спецификацию абстрактного типа данных Deque (очередь

с двумя “хвостами”) на языках Ада и Java (тела методов и тело пакета можно

опустить).

Язык Ада (реализация в виде двунаправленного списка):

generic

type T is private;

package G_Deque is

type Deque is limited private;

procedure PushRight(Deq: inout Deque; X:T);

procedure PushLeft(Deq: inout Deque; X:T);

procedure PopRight(Deq: inout Deque; X: out T);

procedure PopLeft(Deq: inout Deque; X: out T);

procedure Init(Deq: out Deque);

procedure Destroy(Deq: inout Deque);

function IsFull(Deq: Deque);

function IsEmpty(Deq: Deque);

–- другие процедуры ...

private

type PLink is access;

type Link is record inf : T; next, prev : PLink; end record;

type PLink is access Link;

type Deque is record Left, Right: PLink; end record;

end G_Deque;

Язык Java;

interface IDeque<T>

{

void PushLeft(T x);

void PushRight(T x);

T PopLeft();

T PopRight();

bool IsFull();

bool IsEmpty();

// другие функции

}

Замечания:

а). Обобщенные конструкции употреблять не обязательно (надо только

написать, что тип Т должен быть непосредственно видимым в точке

описания типа Deque). Хотя обобщения здесь подходят больше.

б). Структуру типа в Аде полностью выписывать необязательно.

Главное — указать наличие приватной части, например:

private

...

type Deque is …; –- структура типа Deque

end G_Deque;

в). Для языка Java можно выписать не инетерфейс, а конкретный класс

с приватной структурой и публичными функциями-операциями. Тела

функций в этом случае можно не выписывать. Но интерфейс в данном случае

больше подходит к понятию абстрактного типа данных.

7. Ниже приведена спецификация шаблонной функции перемножения

матриц(двумерных массивов) на языке Си++. Напишите пример

конкретизации этой функции, а также соответствующее описание родовой

функции на языке Ада.

template <class T> Matrix<T>& MatMult (Matrix<T>& A,

Matrix<T>&B);

Конкретизация на языке Си++:

Matrix<float> b,c;

Matrix<float> a = MatMult(b,c);

Язык Ада:

generic

type T is private;

with function “+”(x,y:T) return T (<>);

with function “*”(x,y:T) return T (<>);

type Matrix is private;

function G_MatMult(A,B: Matrix) return Matrix;

7. Опишите на языке Ада родовой модуль, реализующий абстрактный

тип данных Queue (очередь). Реализацию процедур и функций писать не

надо.

generic

type T is private;

Size : integer;

package G_Queue is

type Queue is limited private;

procedure Enqueue(Q: inout Queue; X:T);

procedure Dequeue(Q: inout Queue; X:T);

procedure Init(Q: out Queue);

procedure Destroy(Q: inout Queue);

function IsFull(Q: Queue);

function IsEmpty(Q: Queue);

–- другие процедуры ...

private

type Queue is record

Left, Right: integer;

body : array(1..Size) of T;

end record;

end G_Queue;

3. Напишите спецификацию абстрактного типа данных HashTable

(перемешанная таблица, хэш-таблица) на языках Модула-2 и Java (тела

методов и модуль реализации можно опустить).

Язык Модула-2.

DEFINITION MODULE HashTables;

FROM Types IMPORT KeyType, ElementType;

TYPE HashTable;

PROCEDURE Init(VAR T:HashTable);

PROCEDURE Destroy(VAR T:HashTable);

PROCEDURE Lookup(VAR T:HashTable;

Key: KeyType; VAR X:ElementType):BOOLEAN;

PROCEDURE Add(VAR T:HashTable; Key: KeyType; X:ElementType);

PROCDURE Remove(VAR T:HashTable; Key: KeyType):BOOLEAN;

VAR Done: BOOLEAN;

END HashTables.

Язык Java:

interface IHashTable : Iterable

{

ElementType Lookup(KeyType Key);

void Add(KeyType Key, ElementType El);

bool Remove(KeyType Key);

}

Характеристики

Тип файла
Документ
Размер
44,5 Kb
Тип материала
Высшее учебное заведение

Тип файла документ

Документы такого типа открываются такими программами, как Microsoft Office Word на компьютерах Windows, Apple Pages на компьютерах Mac, Open Office - бесплатная альтернатива на различных платформах, в том числе Linux. Наиболее простым и современным решением будут Google документы, так как открываются онлайн без скачивания прямо в браузере на любой платформе. Существуют российские качественные аналоги, например от Яндекса.

Будьте внимательны на мобильных устройствах, так как там используются упрощённый функционал даже в официальном приложении от Microsoft, поэтому для просмотра скачивайте PDF-версию. А если нужно редактировать файл, то используйте оригинальный файл.

Файлы такого типа обычно разбиты на страницы, а текст может быть форматированным (жирный, курсив, выбор шрифта, таблицы и т.п.), а также в него можно добавлять изображения. Формат идеально подходит для рефератов, докладов и РПЗ курсовых проектов, которые необходимо распечатать. Кстати перед печатью также сохраняйте файл в PDF, так как принтер может начудить со шрифтами.

Список файлов ответов (шпаргалок)

Свежие статьи
Популярно сейчас
Как Вы думаете, сколько людей до Вас делали точно такое же задание? 99% студентов выполняют точно такие же задания, как и их предшественники год назад. Найдите нужный учебный материал на СтудИзбе!
Ответы на популярные вопросы
Да! Наши авторы собирают и выкладывают те работы, которые сдаются в Вашем учебном заведении ежегодно и уже проверены преподавателями.
Да! У нас любой человек может выложить любую учебную работу и зарабатывать на её продажах! Но каждый учебный материал публикуется только после тщательной проверки администрацией.
Вернём деньги! А если быть более точными, то автору даётся немного времени на исправление, а если не исправит или выйдет время, то вернём деньги в полном объёме!
Да! На равне с готовыми студенческими работами у нас продаются услуги. Цены на услуги видны сразу, то есть Вам нужно только указать параметры и сразу можно оплачивать.
Отзывы студентов
Ставлю 10/10
Все нравится, очень удобный сайт, помогает в учебе. Кроме этого, можно заработать самому, выставляя готовые учебные материалы на продажу здесь. Рейтинги и отзывы на преподавателей очень помогают сориентироваться в начале нового семестра. Спасибо за такую функцию. Ставлю максимальную оценку.
Лучшая платформа для успешной сдачи сессии
Познакомился со СтудИзбой благодаря своему другу, очень нравится интерфейс, количество доступных файлов, цена, в общем, все прекрасно. Даже сам продаю какие-то свои работы.
Студизба ван лав ❤
Очень офигенный сайт для студентов. Много полезных учебных материалов. Пользуюсь студизбой с октября 2021 года. Серьёзных нареканий нет. Хотелось бы, что бы ввели подписочную модель и сделали материалы дешевле 300 рублей в рамках подписки бесплатными.
Отличный сайт
Лично меня всё устраивает - и покупка, и продажа; и цены, и возможность предпросмотра куска файла, и обилие бесплатных файлов (в подборках по авторам, читай, ВУЗам и факультетам). Есть определённые баги, но всё решаемо, да и администраторы реагируют в течение суток.
Маленький отзыв о большом помощнике!
Студизба спасает в те моменты, когда сроки горят, а работ накопилось достаточно. Довольно удобный сайт с простой навигацией и огромным количеством материалов.
Студ. Изба как крупнейший сборник работ для студентов
Тут дофига бывает всего полезного. Печально, что бывают предметы по которым даже одного бесплатного решения нет, но это скорее вопрос к студентам. В остальном всё здорово.
Спасательный островок
Если уже не успеваешь разобраться или застрял на каком-то задание поможет тебе быстро и недорого решить твою проблему.
Всё и так отлично
Всё очень удобно. Особенно круто, что есть система бонусов и можно выводить остатки денег. Очень много качественных бесплатных файлов.
Отзыв о системе "Студизба"
Отличная платформа для распространения работ, востребованных студентами. Хорошо налаженная и качественная работа сайта, огромная база заданий и аудитория.
Отличный помощник
Отличный сайт с кучей полезных файлов, позволяющий найти много методичек / учебников / отзывов о вузах и преподователях.
Отлично помогает студентам в любой момент для решения трудных и незамедлительных задач
Хотелось бы больше конкретной информации о преподавателях. А так в принципе хороший сайт, всегда им пользуюсь и ни разу не было желания прекратить. Хороший сайт для помощи студентам, удобный и приятный интерфейс. Из недостатков можно выделить только отсутствия небольшого количества файлов.
Спасибо за шикарный сайт
Великолепный сайт на котором студент за не большие деньги может найти помощь с дз, проектами курсовыми, лабораторными, а также узнать отзывы на преподавателей и бесплатно скачать пособия.
Популярные преподаватели
Добавляйте материалы
и зарабатывайте!
Продажи идут автоматически
7041
Авторов
на СтудИзбе
260
Средний доход
с одного платного файла
Обучение Подробнее