Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
 Аватар для MMors
0 / 0 / 0
Регистрация: 30.09.2010
Сообщений: 3

Разделить на Х все элементы списка, которые находятся четных позициях списка

14.02.2011, 09:43. Показов 1373. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет.
Возникла у меня следущая задача.

Есть вот такая программа на С.

Необходимо написать функцию, условие следующее:

Разделить на Х все элементы списка, которые находятся четных позициях списка

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>
#include <conio.h>
 
#define QUE struct que                /* тип даних */
 QUE
  {
   int info;
   QUE *next;
  };
 void insert(QUE **q, int item);
 void display(QUE * q,int pr);
 void add_prev(QUE **q);
 void create_list();
 
QUE *q=NULL;                         /* оголошення списку */
 
void display(QUE * q,int pr)                /* функцiя виведення списку */
    {QUE * current = q;
     if (pr)
       printf("\n\nPervonachal'nyi spisok\n");
     else
       printf("\n\nPreobrazovannyi spisok\n");
     while(current)
       {printf("%d --> ", current->info);
    current = current ->next;
       }
     printf("NILL\n");
    }
 
//void                             /* функция обработки списка */
 
void create_list()                  /* функция создания списка */
   {
    int done=1,
    info, c;
    printf("Sozdanie odnonapravlennogo spiska:\n");
 
    while(done)
      {printf("Dobavit' element? (Y/N)");
       c=getch();
       c=toupper(c);
       switch(c)
       {case 'Y':printf("\n Element=");
             scanf("%d", &info);
             insert(&q, info);
             break;
 
       case 'N': done=0;
             break;
       }
      }
   }
 
void insert (QUE **q, int item)      /* функция вставки элемента в список */
   {
     QUE *current=*q;
     QUE *previous=0;
     QUE *new_node;
      while(current)
     {
       previous=current;
       current=current->next;
     }
     new_node=(QUE*) malloc (sizeof (QUE));
     new_node->info=item;
     if (previous)
     {
       new_node->next=previous->next;
       previous->next=new_node;
      }
     else
     {
       *q=new_node;
       (*q)->next=0;
    }
    }
 
int main()                              /* главная функция */
{
     create_list();
     display(q,1);
     display(q,0);
     getch();
     return 0;
}
Просьба написать отталкиваясь от представленного кода.

ЗАРАНЕЕ ОРГОМНАЯ БЛАГОДАРНОСТЬ!!!!!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.02.2011, 09:43
Ответы с готовыми решениями:

Нужно найти среднее арифметическое число и умножить все цифры из массива которые находятся на нечётных позициях
нужно найти среднее арифметическое число и умножить все цифры из массива которые находятся на нечётных позициях

Разделить одномерный массив на два. Элементы, размещенные на четных и нечетных позициях
Очень нужно решить задачу... 3 ДНЯ ТУПЛЮ СПАСАЙТЕ:wall: Задан одномерный массив действительных чисел из элементов. Сформируйте из этого...

Удалить из списка все элементы, стоящие на четных местах
2. Напишите предикат p(+V, -L) - истинный тогда и только тогда, когда список L получается после удаления из списка V всех элементов,...

2
 Аватар для Novice_1
3 / 3 / 0
Регистрация: 07.02.2011
Сообщений: 81
14.02.2011, 10:09
Хочу помочь, но не могу понять как двигаться по списку((( Вроде должен быть указатель на текущий элемент среди элементов структуры QUE. Если это стандартный тип, то мне стыдно, но я его не знаю))
0
101 / 88 / 7
Регистрация: 17.12.2010
Сообщений: 416
14.02.2011, 15:17
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
void display(QUE * q,int pr)              
{
    QUE * current = q;
        
///////////////////////////////////
        int i=-1;
        int x=2;
        QUE *tmp=q;
/////////////////////////////////////////   
     if (pr)
       printf("\n\nPervonachal'nyi spisok\n");
     else
         //////////////////////////
         //////////////////////////
         while(q){
            ++i;
            (i%2==0) ? (q->info/=x,):;
             q=q->next;
         }
         ////////////////////////////////
         /////////////////////////////////
       printf("\n\nPreobrazovannyi spisok\n");
     while(current)
       {printf("%d --> ", current->info);
        current = current ->next;
       }
     printf("NILL\n");
    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.02.2011, 15:17
Помогаю со студенческими работами здесь

Изъять все слова которые находятся на нечетных порядковых позициях
Как с текста изъять все слова которые находятся на нечетных порядковых позициях.

[Lisp -> Erlang] Произведение элементов списка на четных/нечетных позициях
Имеется программа написанная в лиспе, нужно переделать на Erlang Подсчитывать произведение всех нечетных элементов списка (по месту...

Выделить из списка все элементы, которые делятся на 2 и на 3
Выделить из списка все элементы, которые делятся на 2 и на 3

Объединить два списка в один так, чтобы элементы второго списка, которые есть в первом, в новом списке не были
Prolog Добавлено через 1 минуту Умные люди, помогите пожалуйста!!!!!! Мне на прологе нужно реализовать такую задачу: есть два списка...

Удалить из списка L все элементы, которые есть в списке L1
Используйте линейные списки для хранения последовательности чисел. Опишите процедуру или функцию, которая: a) вставляет в список L за...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru