Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Гостевая книга ... 65535
Содержание сайт... 65535
Вызов хранимых ... 65535
Эмулятор микроп... 65535
Бип из системно... 60692
Invision Power ... 58595
Организация зап... 58569
Модуль Forms 57059
Приложение «Про... 56811
Оператор выбора... 56244
Создание отчето... 55995
Подключение Mic... 55852
ТЕХНОЛОГИИ ДОСТ... 52194
Программируемая... 49487
Пример работы с... 48013
Имитационное мо... 47744
21 ошибка прогр... 42705
Реклама
http://mebiclub.ru/ спальни и мебель для спальни в классическом стиле купить. .
http://avtoskupk.ru/ срочный выкуп автомобилей с выездом срочный.
Сейчас на сайте
Гостей: 14
На сайте нет зарегистрированных пользователей

Пользователей: 13,021
новичок: blizko
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Медиа плейер на Delphi + Пояснительная записка
Моделирование интернет кафе на GPSS + Отчет
Моделирование информационно-поисковой библиографической системы на gpss ...

Реклама

двусвязный список
#include
#include
#include


int dat_mass[100]={1,2,3,14,5,10,1,2,3,4,5,6,7};


typedef struct SP // двусвязный список
{
int data;
struct SP *next,*pred;
} sp;


// создание двусвязного списка заданной длины
sp *sp_new(int len)
{
sp* tmp;
if(len<=0) return NULL;
tmp=(sp*)malloc(sizeof(sp));
if(!tmp) return (sp*)-1;
tmp->next=NULL;
if(len<100) tmp->data=dat_mass[len-1];
else tmp->data=len;
for(len--;len;len--)
{
tmp->pred=(sp*)malloc(sizeof(sp));
if(!tmp->pred)
{
while(tmp->next)
{tmp=tmp->next;
free(tmp->pred);
}
free(dat_mass);
free(tmp);
return (sp*)-1;
}
tmp->pred->next=tmp;
tmp=tmp->pred;
if(len<100) tmp->data=dat_mass[len-1];
else tmp->data=len;
}
tmp->pred=NULL;
free(dat_mass);
return tmp;
}

// удаление двусвязного списка
sp *sp_del(sp* q)
{
if(!q) return NULL;
while(q->pred)
q=q->pred;
while(q->next)
{q=q->next;
free(q->pred);
}
free(q);
return NULL;
}

// вывод на экран двусвязного списка
void sp_print(sp *q)
{
if(q->pred) printf("not first\n");
while(q)
{
printf("%d",q->data);
if(q->next) printf(",");
q=q->next;
}
printf("\n");
}

// подсчет длины двусвязного списка
int sp_len(sp* q)
{
int a;
for(a=0;q;a++,q=q->next);
return a;
}

// поиск элемента по индексу
sp* sp_index(sp*q,int ind)
{
if(ind<0) return NULL;
for (;((ind>0)&&(q));ind--) q=q->next;
return q;
}

// поиск элемента по значению
sp *sp_val(sp* q,int val)
{while(q&&(q->data!=val)) q=q->next;
return q;
}

// удаление элемента из списка
sp *del_item(sp*q)
{sp *tmp;
if(!q) return NULL;
tmp=NULL;
if(q->next)
{q->next->pred=q->pred;
tmp=q->next;
}
if(q->pred)
{q->pred->next=q->next;
tmp=q->pred;
}
free(q);
if(!tmp) return NULL;
while(tmp->pred)
tmp=tmp->pred;
return tmp;
}

// добавление элемента в список
sp *add_item(int a,sp*q,int f)
{sp *t;
t=(sp*)malloc(sizeof(sp));
t->data=a;
if(q==0) {t->pred=t->next=NULL; return t;}

if(f==0)
{t->next=q;
t->pred=q->pred;
q->pred=t;
if(t->pred)
t->pred->next=t;
}
else
{t->pred=q;
t->next=q->next;
q->next=t;
if(t->next)
t->next->pred=t;
}
while(t->pred)
t=t->pred;
return t;
}

int main(int argc, char* argv[])
{
sp *t,*w;
int a;
setlocale(LC_ALL, "Russian");
printf("создан двусвязный список:\n");
t=sp_new(10);
sp_print(t);
a=sp_len(t);
printf("длиной: %i\n", a);
w=sp_index(t,9);
printf("элемент под индексом 9 найден и он равен %d\n",w->data);
w=sp_val(t,10);
printf("элемент со значением %d найден\n",w->data);
w=add_item(99,w,0);
printf("вставлен новый элемент равный 99 перед ранее найденным:\n");
sp_print(w);
printf("удален ранее вставленный элемент:\n");
w=sp_val(w,99);
w = del_item(w);
sp_print(w);
printf("двусвязный список удален\n");
sp_del(t);
system("pause");
return 0;
}



Опубликовал Kest February 22 2014 14:31:13 · 0 Комментариев · 2289 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
Dynamic Titles дл...
В.Понамарев - COM...
Handles
Система баннеро...
OnlineIP
PHP/MySQL для нач...
Comdrv
Delphi на примерах
Библия хакера 2 К...
netBIOS
Animation Effect ...
Фундаментальные а...
PDJPack
CodeGear RAD Stud...
Таймер и секундомер
PHP 5 на примерах
Run
Основы Delphi. Пр...
DiZsubmit
CoolHints2k v1.03

Топ загрузок
Приложение Клие... 100307
Delphi 7 Enterp... 77880
Converter AMR<-... 20021
Borland C++Buil... 10672
GPSS World Stud... 9252
Borland Delphi ... 7658
Turbo Pascal fo... 6884
Visual Studio 2... 4906
Калькулятор [Ис... 3994
FreeSMS v1.3.1 3486
Случайные статьи
Основы перетаскива...
Дорвеи и поисковые...
Найти определитель...
Введение в триггеры
Настройка окон раб...
Механизм сигналов ...
Проектирование сос...
Элементы управлени...
Службы
Нерекурсивное вычи...
Последний вариант ...
Создание простейше...
Транзакции
Что такое процессо...
Доставка грузов
Операторы класса n...
Колебательные проц...
Критические ошибки
Исправленные симво...
В предыдущих верси...
Относитесь к настр...
Выборка и сортиров...
цифровую подпись с...
Где мы находимся?
Проблема ввода-выв...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?