Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [C++] Создать двусвязный список . Задача. 
:(
    Опции темы
Tyurs92
Дата 18.5.2011, 15:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 9
Регистрация: 18.5.2011

Репутация: нет
Всего: нет



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

Вот мой код, но не работает. Подскажите пожалуйста в чём проблема ?

Код

//---------------------------------------------------------------------------
#include <stdio.h>
#include <conio.h>


//---------------------------------------------------------------------------
    struct spis {int n;
            spis*next;
            spis*pred;
           }
           *pm=NULL,*ps,*pp=NULL;
 main()
{int c;
  ps=new spis;

    scanf("%d",&c);
  (*ps).n=c;
  (*ps).pred=NULL;
  (*ps).next=NULL;
  pp=ps;
  pm=ps;
    printf(" dalhe ?  ");
 if(getch()=='1')
 {
 do
 {ps=new spis;

    scanf("%d",&c);
  (*ps).n=c;
  (*ps).pred=pp;
  (*ps).next=NULL;
  (*pp).next=ps;
   pp=ps;
    printf("dalhe ? ");
 }
 while(getch()=='1');
 }
 while(pp!=NULL)
{printf("\n%d",(*pp).n) ;
 pp=(*pp).pred;
}
printf("\n") ;
  while(pp!=NULL)
  {
   if (ps->n==1)
    pp = new spis;
    pp->n=1;
    pp->next=ps->next;
    ps->next=pp;
      printf("\n%d", (*pp).n);
      }

getch();
}


PM MAIL   Вверх
t_gran
Дата 20.5.2011, 08:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 621
Регистрация: 13.11.2007
Где: г.Усть-Илимск

Репутация: 33
Всего: 37



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

#include <cstdio>
#include <cstdlib>
#include <ctime>

struct spis
{
   int n;
   spis *next;
   spis *prev;
}  *list(NULL), *node(NULL);

int main()
{
   unsigned c;

   printf("count elements: ");
   scanf("%d", &c);

   srand(time(NULL));
   while (c--)
   {
      node = new spis;
      node->n = rand() % (c+1);
      node->next = list;
      if (list)
         list->prev = node;
      list = node;
   }

   node = list;
   while (node)
   {
      printf("%d ", node->n) ;
      node = node->next;
   }
   printf("\n") ;

   node = list;
   while (node)
   {
      if (node->n == 1)
      {
         spis *new_node = new spis;
         new_node->n = node->n;
         new_node->next = node->next;
         new_node->prev = node;
         node->next = new_node;
         if (new_node->next)
            new_node->next->prev = new_node;
         node = new_node;
      }

      node = node->next;
   }

   node = list;
   while (node)
   {
      printf("%d ", node->n) ;
      node = node->next;
   }
   printf("\n") ;

   return 0;
}



Присоединённый файл ( Кол-во скачиваний: 3 )
Присоединённый файл  list.7z 21,82 Kb


--------------------
Я знаю, что ничего не знаю© Сократ
user posted image
PM MAIL WWW   Вверх
Tyurs92
Дата 20.5.2011, 23:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 9
Регистрация: 18.5.2011

Репутация: нет
Всего: нет



Спасибо большое ! Очень помогли , но не могли бы вы чуть - чуть изменить код. Понимаете , список не должен быть случайным , а должен вводиться с экрана.

Примерно выглядит следующим образом :

Вводим первый элемент: 2

Спрашиваем "будете продолжать ?" ( Если будем, то нажимаем 1, если нет - то печатается список.(может быть из одного элемента))

Вводим второй элемент: 1

Опять спрашиваем

Вводим третий элемент: 4

и т. д.

Когда заканчиваем ввод на вопрос: "будете продолжать ?" нажимаем "Enter",  то печатается так:

2
1
1 ( дублированная единица)
4

Ещё раз большое СПАСИБО !!!
PM MAIL   Вверх
t_gran
Дата 23.5.2011, 05:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 621
Регистрация: 13.11.2007
Где: г.Усть-Илимск

Репутация: 33
Всего: 37



Tyurs92, так в Вашей же версии это уже реализовано. smile Осталось только подставить.
Код

#include <cstdio>

struct spis
{
   int n;
   spis *next;
   spis *prev;
}  *list(NULL), *node(NULL);

int main()
{
   int digit = 0;
   printf("list elemrnts (input -1 for exit): ");

   bool exit = false;
   while (!exit)
   {
      scanf("%d", &digit);
      if (digit == -1)
      {
         exit = true;
      }
      else
      {
         node = new spis;
         node->n = digit;
         node->next = list;
         if (list)
            list->prev = node;
         list = node;
      }
   }

   node = list;
   while (node)
   {
      printf("%d ", node->n) ;
      node = node->next;
   }
   printf("\n") ;

   node = list;
   while (node)
   {
      if (node->n == 1)
      {
         spis *new_node = new spis;
         new_node->n = node->n;
         new_node->next = node->next;
         new_node->prev = node;
         node->next = new_node;
         if (new_node->next)
            new_node->next->prev = new_node;
         node = new_node;
      }
      node = node->next;
   }

   node = list;
   while (node)
   {
      printf("%d ", node->n) ;
      node = node->next;
   }
   printf("\n") ;

   return 0;
}


user posted image

Присоединённый файл ( Кол-во скачиваний: 6 )
Присоединённый файл  list.7z 21,81 Kb


--------------------
Я знаю, что ничего не знаю© Сократ
user posted image
PM MAIL WWW   Вверх
Tyurs92
Дата 23.5.2011, 22:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 9
Регистрация: 18.5.2011

Репутация: нет
Всего: нет



Спасибо вам Большое !!! Премного благодарен !!!
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.0955 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.