Форум программистов, компьютерный форум CyberForum.ru

Задачка с динамической памятью и вводом из файла - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Работа с устройствами http://www.cyberforum.ru/cpp/thread20252.html
Здравствуйте, как я понял, как выключить интернет никто не знает... Я порылся еще в гугле, но безрезультатно. В итоге я понял, что походу - некак) Но нашелся другой способ - отключить сам девайс. Отсюда выплывает вопрос, кто знает, как работать с устройствами, что для этого нужно. Может кто подкинет функции которые для этого используются? Спасибо.
C++ Задачи с массивами Помогите мне пожалуйста с задачками::help: :help:::help::wall: 1. Записать положительные элементы массива X = (х1, х2,..., x12) подряд в массив Y = (y1, y2,..., yk). Определить (к) - количество положительных элементов. Вычислить сумму элементов массива Y. 2. Из массива С(5,4) сформировать массив М(5), каждый элемент которого равен сумме абсолютных значений элементов соответствующей строки... http://www.cyberforum.ru/cpp/thread20251.html
Программное отключение\включение ADSL C++
Здравствуйте, есть ли у кого соображение по поводу, как программно отключить\включить ADSL интернет?
C++ Как програмировать на с++ под WM6?
Кто-нибудь знает как програмировать на с++ под WM6? что надо сделать что-бы хотябы вот это заработало: #include <iostream> int main() { std::cout<<"Hello world!"<<std::endl; return 0; }
C++ Блокировка цифер на клавиатуре http://www.cyberforum.ru/cpp/thread19618.html
Помогите пожалуйста написать программу, которая будет реагировать на нажатие комбинации клавиш Ctrl+Shift+F3 и блокирует цифры на клавиатуре, а при повторном нажатии клавиш разблокирует. Буду благодарен за любую помощь. :)
C++ Презагрузка драйвера У меня переодически летит драйвер на модем беспроводного соеденения ,живу с этим давно -уже должен свыкнутся ,но мне это надоело .Вместо того что-бы каждый раз вставать ,выдергивать и вставлять обратно модем ,хочу написать прогу (или строковое обращение) с помощью которой можно выгрузить а потом загрузить драйвер обратно (т.е. выполнить его перезагрузку) .Кто знает подскажите как это зделать в... подробнее

Показать сообщение отдельно
Splitter
201 / 143 / 5
Регистрация: 13.01.2009
Сообщений: 554
18.01.2009, 14:12     Задачка с динамической памятью и вводом из файла
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
class List
{
public:
    struct Node 
    {
        Node(const int& data, Node* next=0):data(data),next(next) {}
        Node* next;
        int data;
    };
 
    List() : head(0) {}
 
    List(const List& L) : head(0)
    {
        for ( const Node* i = L.begin(); i!= L.end(); i=i->next )
            push_front(i->data);
        reverse();
    }
 
    void reverse()
вот, классический односвязный список, таких примеров в инете полно, почитайте хотябы вот эту темку...

http://www.cap-design.ru/ccc/165.htm

там все подробно, с хорошими примерами..., Можно конечно написать и програмку, но экзамен то Вам сдавать...

Добавлено через 1 минуту 56 секунд
вдогонку, не все скопировал.... вот все...

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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
class List
{
public:
    struct Node 
    {
        Node(const int& data, Node* next=0):data(data),next(next) {}
        Node* next;
        int data;
    };
 
    List() : head(0) {}
 
    List(const List& L) : head(0)
    {
        for ( const Node* i = L.begin(); i!= L.end(); i=i->next )
            push_front(i->data);
        reverse();
    }
 
    void reverse()
    {
        Node* p = 0; Node* i = begin(); Node* n;
        while (i)
        {
            n = i->next;
            i->next = p;
            p = i; i = n;
        }
        head = p;
    }
 
    void swap(List& x)
    {
        Node* tmp = head; head = x.head; x.head = tmp;
    }
 
    List& operator=(const List& x)
    {
        List tmp(x);
        swap(tmp);
        return *this;
    }
 
    ~List() { clear(); }
    void clear() { while (!empty()) pop_front(); }
 
    bool empty() { return ! head; }
 
    void push_front(const int& x) { 
        Node* tmp = new Node(x,head); head = tmp; 
    }
 
    void pop_front() { 
        if (head) { Node* tmp = head; head=head->next; delete tmp; }
    }
 
    void insert_after(Node* x, const int& data)
    {
        Node* tmp = new Node(data, x->next);
        x->next = tmp;
    }
 
    void erase_after(Node* x)
    {
        Node* tmp = x->next;
        if (tmp)
        {
            x->next = x->next->next;
            delete tmp;
        }
    }
 
 
    int& front() { return head->data; }
    const int& front() const { return head->data; }
 
    Node* begin() { return head; }
    Node* end() { return 0; }
 
    const Node* begin() const { return head; }
    const Node* end() const { return 0; }
 
private:
    Node* head;
};
 
#include <iostream>
using namespace std;
 
int main()
{
    List X;
    X.push_front(3);
    X.push_front(2);
    X.push_front(1);
 
    for (List::Node* it = X.begin(); it; it = it->next )
        cout << it->data << endl;
 
    X.reverse();
 
    for (List::Node* it = X.begin(); it; it = it->next )
        cout << it->data << endl;
    return 0;
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru