Банк рефератов содержит более 364 тысяч рефератов, курсовых и дипломных работ, шпаргалок и докладов по различным дисциплинам: истории, психологии, экономике, менеджменту, философии, праву, экологии. А также изложения, сочинения по литературе, отчеты по практике, топики по английскому.
Полнотекстовый поиск
Всего работ:
364139
Теги названий
Разделы
Авиация и космонавтика (304)
Административное право (123)
Арбитражный процесс (23)
Архитектура (113)
Астрология (4)
Астрономия (4814)
Банковское дело (5227)
Безопасность жизнедеятельности (2616)
Биографии (3423)
Биология (4214)
Биология и химия (1518)
Биржевое дело (68)
Ботаника и сельское хоз-во (2836)
Бухгалтерский учет и аудит (8269)
Валютные отношения (50)
Ветеринария (50)
Военная кафедра (762)
ГДЗ (2)
География (5275)
Геодезия (30)
Геология (1222)
Геополитика (43)
Государство и право (20403)
Гражданское право и процесс (465)
Делопроизводство (19)
Деньги и кредит (108)
ЕГЭ (173)
Естествознание (96)
Журналистика (899)
ЗНО (54)
Зоология (34)
Издательское дело и полиграфия (476)
Инвестиции (106)
Иностранный язык (62791)
Информатика (3562)
Информатика, программирование (6444)
Исторические личности (2165)
История (21319)
История техники (766)
Кибернетика (64)
Коммуникации и связь (3145)
Компьютерные науки (60)
Косметология (17)
Краеведение и этнография (588)
Краткое содержание произведений (1000)
Криминалистика (106)
Криминология (48)
Криптология (3)
Кулинария (1167)
Культура и искусство (8485)
Культурология (537)
Литература : зарубежная (2044)
Литература и русский язык (11657)
Логика (532)
Логистика (21)
Маркетинг (7985)
Математика (3721)
Медицина, здоровье (10549)
Медицинские науки (88)
Международное публичное право (58)
Международное частное право (36)
Международные отношения (2257)
Менеджмент (12491)
Металлургия (91)
Москвоведение (797)
Музыка (1338)
Муниципальное право (24)
Налоги, налогообложение (214)
Наука и техника (1141)
Начертательная геометрия (3)
Оккультизм и уфология (8)
Остальные рефераты (21692)
Педагогика (7850)
Политология (3801)
Право (682)
Право, юриспруденция (2881)
Предпринимательство (475)
Прикладные науки (1)
Промышленность, производство (7100)
Психология (8692)
психология, педагогика (4121)
Радиоэлектроника (443)
Реклама (952)
Религия и мифология (2967)
Риторика (23)
Сексология (748)
Социология (4876)
Статистика (95)
Страхование (107)
Строительные науки (7)
Строительство (2004)
Схемотехника (15)
Таможенная система (663)
Теория государства и права (240)
Теория организации (39)
Теплотехника (25)
Технология (624)
Товароведение (16)
Транспорт (2652)
Трудовое право (136)
Туризм (90)
Уголовное право и процесс (406)
Управление (95)
Управленческие науки (24)
Физика (3462)
Физкультура и спорт (4482)
Философия (7216)
Финансовые науки (4592)
Финансы (5386)
Фотография (3)
Химия (2244)
Хозяйственное право (23)
Цифровые устройства (29)
Экологическое право (35)
Экология (4517)
Экономика (20644)
Экономико-математическое моделирование (666)
Экономическая география (119)
Экономическая теория (2573)
Этика (889)
Юриспруденция (288)
Языковедение (148)
Языкознание, филология (1140)

Реферат: Разработка линейного однонаправленного списка

Название: Разработка линейного однонаправленного списка
Раздел: Рефераты по информатике
Тип: реферат Добавлен 10:44:57 25 июня 2011 Похожие работы
Просмотров: 21 Комментариев: 21 Оценило: 2 человек Средний балл: 5 Оценка: неизвестно     Скачать

МИНИСТЕРСТВО ОБРАЗОВАНИЯ И НАУКИ РОССИЙСКОЙ ФЕДЕРАЦИИ

ФЕДЕРАЛЬНОЕ АГЕНТСТВО ПО ОБРАЗОВАНИЮ

ГОСУДАРСТВЕННОЕ ОБРАЗОВАТЕЛЬНОЕ УЧРЕЖДЕНИЕ

ВЫСШЕГО ПРОФЕССИОНАЛЬНОГО ОБРАЗОВАНИЯ

«НОВОСИБИРСКИЙ ГОСУДАРСТВЕННЫЙ ТЕХНИЧЕСКИЙ УНИВЕРСИТЕТ»

КУЙБЫШЕВСКИЙ ФИЛИАЛ

Курсовой проект

По дисциплине: Программирование

На тему: « Разработка линейного однонаправленного списка»

Выполнил студент

группы ВТК-281

Киселёв С.А.

.

_______________

(подпись, дата)

Проверил:

Бычков М.И.

Куйбышев 2010

Задание:

Разработать программу реализующая следующие элементы списка:

Вставка, удаление, вывод на экран, чтение из файла, удаление последнего элемента и удаление всех элементов списка, осуществляет выход из программы.

Структурное и функциональное описание программы:

//-------------------------------Подключение библиотек--------------------------

#include <iostream> // Стандартные потоки ввода-вывода:

// ios,istream,ostream,iostream

#include <conio>

#include <windows>

#include <stdio>

#include <stdlib>

#include <fstream> // Файловые потоки ввода-вывода:

//------------------------Русификатор------------------------------------------------

void rus(char *str)

{

char buf[100];

CharToOem(str,buf);

cout<<buf;

return;

}

//------------------------Вывод на экран меню и запись значения--------------

int menu()

{int n;

rus(" Меню ");cout<<"\n";

rus(" ");cout<<"\n";

rus(" 1 - Вставка ");cout<<"\n";

rus(" 2 - Удаление ");cout<<"\n";

rus(" 3 - Вывод на экран ");cout<<"\n";

rus(" 4 - Сохранение ");cout<<"\n";

rus(" 5 - Чтение");cout<<"\n";

rus(" 6 - Удаление всего списка");cout<<"\n";

rus(" 0 - Выход ");cout<<"\n";

rus("==============================");cout<<"\n";

rus(" Введите пункт меню ");cout<<"\n";

cin>>n; return n;} // ввод с клавиатуры

//-----------------------------------------------------------------------------------

struct node{char x[15]; node *next;};

node *un=NULL; //создаём указатели на начало списка

node *uk=un; //создаём указатель на конец списка

node *r,*pre; //ещё 2 указателя

int count;

//--------------------------------Удаление всего списка-------------------------

void dellist(node *p) // функция удаления

{

while(p){delete p; p=p->next;

}

uk=un;

}

//----------------------------------Удаление------------------------------------

void delet(node*p)

{

node *h=p;

if(p==uk)

{

uk=p->next;delete h;

}

else

{

node *f=p->next;

p->next=(p->next)->next;

delete f;

}

}

//-----------------------------------Сохранение---------------------------------

void save(node *p)

{

ofstream out("a.txt");

while(p)

{ out<<p->x<<"\n";

p=p->next;

}

rus("СОХРАНЕНО!!!"); cout<<"\n";

}

//-------------------------Print------------------------------------------------

void show(node *z){while(z){cout<<z->x<<"_____"<<z<<"\n";z=z->next;}}

//--------------------------Запись в структуру------------------------

node* insert(node *p)

{

node *q=new node;

rus("Введите значение \n");

textcolor(RED);

rus ("!!!не более 15 символов!!!\n\n");

gotoxy(1.5,wherey());

cin>>q->x; q->next=p;

return q;

}

//--------------------------Запись в структуру----------------------------------

node* insert(node *p, char* str)

{

node *q=new node;

strcpy(q->x, str); //функция копирования

q->next=p;

return q; // функция возвращения переменной

}

int GetCountEl(node *p)

{

int n = 0;

while(p) //цикл с предусловием

{

n++;

p=p->next;

}

return n;

}

char* getEl(const int &num)

{

if(num < count) // структура (вид – ветвление)

{

node *p = uk;

for(int i=0; i<num; i++)

p = p->next;

return p->x;

}

else return 0; // иначе возвращается 0

}

void exchange(const int &dpos, const int &spos)

{

if((dpos<count)&&(spos<count))

{

int i;

char* temp;

temp = new char[15];

node *dest = uk;

node *source = uk;

for(i=0;i<dpos;i++) dest = dest->next;

for(i=0;i<spos;i++) source = source->next;

strcpy(temp, source->x);

strcpy(source->x, dest->x);

strcpy(dest->x, temp);

}

}

//--------------Загрузка--------------------------

loading()

{

char *str;

str = new char[15];

ifstream inf("a.txt");

if (!inf)

{

rus("Ошибка при открытии файла!\n\n\n");

} else

{

while (!inf.eof())

{

inf.getline(str,15); //введенная из файла строка

if (strcmp("",str)) uk = insert(uk, str);

}

rus("Данные успешно загружены!\n\n\n");

}

}

//-------------------------Главная функция-----------------------------------

int main()

{ int n=1;

while(n){char x[15];

n=menu();

switch(n) // оператор выбора

{

case 1:clrscr();

cin>>x; uk=insert(uk,x);break;

case 2:clrscr();delet(uk);break;

case 3:clrscr();show(uk);break;

case 4:clrscr();save(uk);break;

case 5:clrscr();loading();break;

case 6:clrscr();dellist(uk);break;

case 0:clrscr();exit(0);

}

}

getch();

}

Схема

Вывод: эта программа выполняет ввод данных с клавиатуры, сохранение в файл и чтение из него; удаление элементов или всего списка, осуществляет просмотр и выход из программы, то есть она выделяет динамическую память для ввода данных с клавиатуры, сохраняет данные в файл. Можно загрузить данные из файла. Редактирует список с помощью удаления элемента списка, а так же возможно удалить список полностью и начать заполнение списка заново.

Оценить/Добавить комментарий
Имя
Оценка
Комментарии:
Хватит париться. На сайте FAST-REFERAT.RU вам сделают любой реферат, курсовую или дипломную. Сам пользуюсь, и вам советую!
Никита04:38:38 04 ноября 2021
.
.04:38:36 04 ноября 2021
.
.04:38:34 04 ноября 2021
.
.04:38:32 04 ноября 2021
.
.04:38:31 04 ноября 2021

Смотреть все комментарии (21)
Работы, похожие на Реферат: Разработка линейного однонаправленного списка

Назад
Меню
Главная
Рефераты
Благодарности
Опрос
Станете ли вы заказывать работу за деньги, если не найдете ее в Интернете?

Да, в любом случае.
Да, но только в случае крайней необходимости.
Возможно, в зависимости от цены.
Нет, напишу его сам.
Нет, забью.



Результаты(294402)
Комментарии (4230)
Copyright © 2005 - 2024 BestReferat.ru / реклама на сайте