Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Удаление двунаправленного списка





Операция удаления двунаправленного списка реализуется аналогично удалению однонаправленного списка.

//освобождение памяти, выделенной под двунаправленный список

void Delete_Double_List(Double_List* Head){

if (Head!= NULL){

Delete_Double_List(Head->Next);

delete Head;

}

}

Пример 1. N -натуральных чисел являются элементами двунаправленного списка L, вычислить: X1*Xn+X2*Xn-1+...+Xn*X1. Вывести на экран каждое произведение и итоговую сумму.

Алгоритм:

  1. Создаём структуру.
  2. Формируем список целых чисел.
  3. Продвигаемся по списку: от начала к концу и от конца к началу в одном цикле, перемножаем данные, содержащиеся в соответствующих элементах списка.
  4. Суммируем полученные результаты.
  5. Выводим на печать

Создание структуры, формирование списка и вывод на печать рассмотрены ранее. Приведем функции для реализации продвижения по списку в обоих направлениях и нахождения итоговой суммы.

//поиск последнего элемента списка

Double_List* Find_End_Item_Double_List(Double_List* Head){

Double_List *ptr; //дополнительный указатель

ptr = Head;

while (ptr->Next!= NULL){

ptr = ptr->Next;

}

return ptr;

}

 

//итоговая сумма произведений

void Total_Sum(Double_List* Head) {

Double_List* lel = Head;

Double_List* mel = Find_End_Item_Double_List(Head);

int mltp,sum=0;

while(lel!= NULL) {

mltp = (lel->Data)*(mel->Data);//умножение элементов

printf("\n\n%d * %d = %d",lel->Data,mel->Data,mltp);

sum = sum + mltp;//суммирование произведений

lel = lel->Next;

//идем по списку из первого элемента в последний

mel = mel->Prior;

//идем по списку из последнего элемента в первый

}

printf("\n\n Итоговая сумма равна %d",sum);

}







Дата добавления: 2015-08-12; просмотров: 450. Нарушение авторских прав; Мы поможем в написании вашей работы!




Шрифт зодчего Шрифт зодчего состоит из прописных (заглавных), строчных букв и цифр...


Картограммы и картодиаграммы Картограммы и картодиаграммы применяются для изображения географической характеристики изучаемых явлений...


Практические расчеты на срез и смятие При изучении темы обратите внимание на основные расчетные предпосылки и условности расчета...


Функция спроса населения на данный товар Функция спроса населения на данный товар: Qd=7-Р. Функция предложения: Qs= -5+2Р,где...

Этические проблемы проведения экспериментов на человеке и животных В настоящее время четко определены новые подходы и требования к биомедицинским исследованиям...

Классификация потерь населения в очагах поражения в военное время Ядерное, химическое и бактериологическое (биологическое) оружие является оружием массового поражения...

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

Тема 2: Анатомо-топографическое строение полостей зубов верхней и нижней челюстей. Полость зуба — это сложная система разветвлений, имеющая разнообразную конфигурацию...

Виды и жанры театрализованных представлений   Проживание бронируется и оплачивается слушателями самостоятельно...

Что происходит при встрече с близнецовым пламенем   Если встреча с родственной душой может произойти достаточно спокойно – то встреча с близнецовым пламенем всегда подобна вспышке...

Studopedia.info - Студопедия - 2014-2025 год . (0.012 сек.) русская версия | украинская версия