Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
RomaSeba
0 / 0 / 0
Регистрация: 04.11.2015
Сообщений: 37
#1

Реализация функции c++ - C++

21.05.2016, 22:03. Просмотров 289. Ответов 3
Метки c++ (Все метки)

Программа:
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
#include <iostream>
using namespace std;
 
struct Node {
    int data;
    Node* next;
};
 
 
 
Node* arrayToList(const int arr[], size_t size) {
 
    if(!size) return 0;
    
    Node * aa = new Node;
    aa->data = arr[0];
    aa->next = 0;
    return aa;
 
}
 
 
 
Node* removeOdd(Node* head) {
 
 
}
 
 
void showList(const Node* head) {
    
    if (! head) {
        cout << "List is empty" << endl;
    return;
    }
 
    else{
        Node *aaa = const_cast<Node*>(head);
        while(aaa)
          {
              cout << aaa->data << " ";
              aaa = head->next;
          }
           cout << endl;
        }
 
}
 
 
void deleteList(Node*& head) {
 
    while(head)
        {
            
        Node *aaa = head;
        head = head->next;
          cout << "deleting " << aaa->data << ".";
        delete aaa;
        }
       cout << endl;
 
}
 
 
int main() {
    int arr[] = {1,2,3,4,5,6};
    size_t size = sizeof(arr)/sizeof(*arr);
    Node* head = arrayToList(arr,size);
    showList(head);
    head = removeOdd(head);
    showList(head);
    deleteList(head);
    showList(head);
}
Возникли трудности при реализации функции Node* removeOdd. Не въезжаю, как ее написать. Требования такие:
Node* removeOdd(Node* head) принимает указатель на первый элемент списка, а возвращает указатель на первый элемент нового списка, который создастся после удаления из изначального списка всех связей, в которых data является нечетным. Функция не должна создавать новых связей-только удалять те с нечетными данными. Если в списке есть только нечетные числа, то все связи должны быть удалены, а функция должна возвратить nullptr. При этом нужно сделать так, чтобы при каждом удалении функция выписывала удаляемые данные
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.05.2016, 22:03
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Реализация функции c++ (C++):

Реализация функции itoa - C++
помогите написать реализацию функции itoa MyItoa(int,char*,int) и пожалуйста с комменториями

Реализация функции srcat. - C++
Я написал (реализовал) функцию strcat. Вот ... #include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;iomanip&gt; using namespace std;...

Реализация функции erase() - C++
Как работает erase()? То есть, если у нас : prev, it, next - итераторы и выполняя erase(it), она очистит память, которую занимала it и...

Реализация функции strtok - C++
Добрый день. Мое задание звучит так: изучите поведение функции strtok из стандартной библиотеки. Реализуйте и...

Реализация friend функции - C++
Есть код. Нужно реализовать вывод ответа через friend. Подскажите пожалуйста как это сделать? Ничего не получается... #include &lt;iostream&gt;...

Реализация функции палиндрома - C++
Я написала функцию, функция нормально работает. Но так как я смотрела по примерам, мне не очень нравиться этот момент: for (t = str;...

3
Unknownx
Заблокирован
21.05.2016, 22:31 #2
RomaSeba, у тебя по заданию использовать только односвязный список или это ты так решил?
Эта задача и гроша ломаного не стоит если делать через двусвязный список.
0
RomaSeba
0 / 0 / 0
Регистрация: 04.11.2015
Сообщений: 37
21.05.2016, 22:52  [ТС] #3
В задании так сказано
0
Unknownx
Заблокирован
21.05.2016, 22:58 #4
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
Ладно тогда вот с односвязным
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
#include <iostream>
using namespace std;
 
struct Node {
    int data;
    Node* next;
};
 
Node* arrayToList(const int arr[], size_t size) {
    Node*  list = /*nullptr*/0;
    Node*  item = /*nullptr*/0;
    if(!size) return 0;
    for( size_t elem = 0; elem < size; elem++ )
    {
        Node * a = new Node;
        a->data = arr[elem];
        a->next = 0;
        if( item )
        {
            item->next = a;
            item = item->next;
        }
        else
            list =item = a;
    }
    return list;
 
}
 
Node* removeOdd(Node* head) {
    Node*  list = /*nullptr*/0;
    Node*  item = /*nullptr*/0;
    Node*  prev = /*nullptr*/0;
    if ( (item = prev = head) != 0 )
    {
        for( item = item->next; item; item = item->next )
        {
            if( item->data % 2 )
            {
                prev->next = item->next;
                cout<<"delete : "<<item->data<<endl;
                delete item;
                item = prev;
            }
            else
                prev = item;
        }
        if( head->data % 2 )
        {
            list = head->next;
            cout<<"delete : "<<head->data<<endl;
            delete head;
        }
    }
    return list;
}
 
void showList(const Node* head) {
    
    if (! head) {
        cout << "List is empty" << endl;
    return;
    }
    else
    {
        Node *list = const_cast<Node*>(head);
        while(list)
        {
            cout << list->data << " ";
            list  = list->next;
        }
        cout << endl;
    }
}
 
 
int main(){
    int arr[] = {1,2,3,4,5,6};
    size_t size = sizeof(arr)/sizeof(*arr);
    Node* list  = arrayToList(arr, size);
    showList(list);
    list = removeOdd(list);
    showList(list);
    cin.get();
    return 0;
}
http://codepad.org/cVQgJYjM
[QUOTE]1 2 3 4 5 6
delete : 3
delete : 5
delete : 1
2 4 6 [/QOUTE]

Добавлено через 2 минуты

Не по теме:

Цитата Сообщение от RomaSeba Посмотреть сообщение
Возникли трудности при реализации функции Node* removeOdd. Не въезжаю, как ее написать.
- а должны были ещё вопросы с
Цитата Сообщение от RomaSeba Посмотреть сообщение
Node* arrayToList(const int arr[], size_t size)
возникнуть, сам свой же код анализировал? Напиши словами конкретно по строчкам что делаешь в той функции и увидишь какой колосальный баг сделал. (Даю подсказу -
Цитата Сообщение от RomaSeba Посмотреть сообщение
aa->data = arr[0];
- это не доабвление массива а всего лишь создание итема с инициализацией первым элементом массива)

0
21.05.2016, 22:58
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
21.05.2016, 22:58
Привет! Вот еще темы с ответами:

Реализация функции принтф - C++
Хелпуем товарищи, треба написать свою фукнцию принтф с форматной строкой(правда она слегка иная, чтобы не путать с уже существующей) ...

реализация ThreadSafe функции - C++
Пишу статическую библиотеку функций, на основе которой разрабатывают приложения. При создании многопоточных приложений на её основе...

Собственная реализация функции конкатенации - C++
Вопрос в комментарии к коду. Объясните пожалуйста (см. ниже что именно) #include &lt;stdio.h&gt; void strсat(char *s1, char *s2) { ...

Реализация дружественной (friend) функции - C++
Всем доброго времени суток. Хотел бы попросить помощи, ибо запутался. Задачи состоит в том, чтобы произвести сравнение объекта...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru