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

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

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 11, средняя оценка - 5.00
lolopolosko
1354 / 312 / 5
Регистрация: 21.11.2009
Сообщений: 992
#1

Поместить в список строки - C++

13.12.2009, 20:57. Просмотров 1626. Ответов 27
Метки нет (Все метки)

Подскажите или покажите на примере как поместить в список несколько строк...?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
13.12.2009, 20:57
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Поместить в список строки (C++):

Поместить 25 случайных целых чисел в диапазоне от 0 до 100 в упорядоченный список - C++
Напишите программу, которая помещает 25 случайных целых чисел в диапазоне от 0 до 100 в упорядоченный список. Вычислите сумму и среднее...

Список. Найти сумму элементов, больших 3 и меньших 8 и поместить ее в начало списка - C++
Помогите мне пожалуйста Создать программу для создания списка из 10 целых чисел, вводимых с клавиатуры и вывода его на экран....

Односвязный список: уничтожить н-ный эл-т и на его место поместить эл-т, нр которого хранится в н-ном эл-те - C++
Написать функцию, которая уничтожает n-ный элемент в списке и на его место помещает элемент, номер которого хранится в n-ном элементе....

Как поместить строки в .dll ?? - C++
Как туда поместить функции я разобрался ... А вот строки и другие ресурсы - никак.

Считать строки файла и поместить в динамический массив строк - C++
Ребята помогите. Нужно считать с файла, в котором 1 строка - 1 слово, строки и поместить их в динамический массив строк типа char...

Выделить из строки числа (только целые) и поместить их в массив по возрастанию - C++
#include <iostream> #include <string.h> using namespace std; void find_integers_in_string(char* strok, char* arry, int& n) //...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
outoftime
║XLR8║
509 / 431 / 33
Регистрация: 25.07.2009
Сообщений: 2,295
13.12.2009, 21:01 #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
#include <iostream>
#include <string>
#include "mstack.hpp"
 
using namespace std;
 
int main()
{
    mstack <string> s;
    int key;
    string val;
    do
    {
        system("cls");
        cout << "\tStack\t\t\t\tmade by TFTM\n\n";
        cout << "1 - push\n";
        cout << "2 - pop & write\n";
        cout << "3 - exit\n\n";
        cout << "press key: ";
        cin >> key;
        switch (key)
        {
            case 1:
                {
                    cout << "\nenter element: ";
                    cin >> val;
                    s.push(val);
                    break;    
                }
            case 2:
                {
                    if (s.empty()) cout << "stack is empty..";
                    else
                    {
                        cout << "poping:\n";
                        while (!s.empty())
                            cout << s.pop() << endl;
                    }
                    system("pause");
                    break;    
                }
            default:
                {
                    if (key == 3) cout << "exiting succesfully..\n";
                    else cout << "press only 1, 2 or 3\n";
                    system("pause");
            }                
        }
    }
    while (key != 3);
    
    return 0;
}
заголовочный файл
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
template <typename T>
struct node
{
    T inf;
    node<T>* next;
};
 
template <typename T>
class mstack
{
private:
    node<T>* head;
public:
    mstack(){head = NULL;}
    ~mstack(){}
    
    void push(T &val)
    {
        node<T>* tmp = new node<T>;
        tmp->inf = val;
        tmp->next = head;
        head = tmp;
    }
    
    void clear()
    {
        while (head->next != NULL)
        {
            node<T>* tmp = head;
            head = head->next;
            delete tmp;
        }
        head = NULL;
    }
    
    bool empty(){return (head == NULL);}
    
    T pop()
    {
        T res = head->inf;
        node<T>* tmp = head;
        head = head->next;
        delete tmp;
        return res;
    }
};

сам попросил
lolopolosko
1354 / 312 / 5
Регистрация: 21.11.2009
Сообщений: 992
13.12.2009, 21:53  [ТС] #3
ща попробую)))

Добавлено через 11 минут
все норм...чучуть изминил и пошло)а то стандартный шаблон list не хочет почемуто принимать строки у меня
outoftime
║XLR8║
509 / 431 / 33
Регистрация: 25.07.2009
Сообщений: 2,295
13.12.2009, 21:57 #4
напиши свой, что тебе мешает?
lolopolosko
1354 / 312 / 5
Регистрация: 21.11.2009
Сообщений: 992
13.12.2009, 22:22  [ТС] #5
я просто ща здаю лабораторные роботы...а свой шаблон list я уже писал но только он односвязный или как там говорят ....этот шаблон тоже очень похож на список....ток возвращает даные как стек
outoftime
║XLR8║
509 / 431 / 33
Регистрация: 25.07.2009
Сообщений: 2,295
13.12.2009, 23:57 #6
тебе линковку надо делать не с первого на последующий а с последующего на первый, и держать еще один указатель на последний элемент, тогда когда ты его пройдешь все будет в прямой последовательности..
NULL <- 1 <- 2 <- ... <- n - list (begin <- ... <- end)
1 -> 2 -> 3 -> ... -> NULL - stack (begin -> ... -> end)
perchik71
69 / 27 / 2
Регистрация: 08.08.2009
Сообщений: 60
14.12.2009, 00:08 #7
Цитата Сообщение от lolopolosko Посмотреть сообщение
Подскажите или покажите на примере как поместить в список несколько строк...?

как я тя понял

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <list.h>
#include <iostream.h>
void main()
{
char buf[MAX_PATH];
list<char*> spisok;
int kol;
cout<<"Ведите кол-во строк "; cin>>kol;
while(kol)
{
cout<<"Ведите строку "; cin>>buf;
spisok.push_back(buf);
kol--;
}
}
вот терь все твои строки в spisok записаны
Андрейка
419 / 223 / 27
Регистрация: 25.03.2009
Сообщений: 744
14.12.2009, 00:12 #8
lolopolosko,
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include <algorithm>
#include <string>
#include <list>
#include <iostream>
 
int main()
{
    std::list <std::string> lst;
    lst.push_back("hi");
    lst.push_back("world");
    std::copy(lst.begin(),lst.end(),std::ostream_iterator<std::string>(std::cout," "));
    system("pause");
    return 0;
}
стандартный list
outoftime
║XLR8║
509 / 431 / 33
Регистрация: 25.07.2009
Сообщений: 2,295
14.12.2009, 00:14 #9
Андрейка, так ведь ему на лабу свой надо))
perchik71
69 / 27 / 2
Регистрация: 08.08.2009
Сообщений: 60
14.12.2009, 00:22 #10
Цитата Сообщение от outoftime Посмотреть сообщение
Андрейка, так ведь ему на лабу свой надо))
Оо
писал давно правд .... и больше 2 раз в приложении я не смог использовать поэтому освоился с list зачём париться над тем что уже придумали ))))
Андрейка
419 / 223 / 27
Регистрация: 25.03.2009
Сообщений: 744
14.12.2009, 00:27 #11
perchik71, парятся обычно чтобы узнать как работает структура , что такое указатели на след и пред элемент ( в данном случае) то есть программируя сам ты узнаешь почему так делается. а std::list используют чтобы не тратить время на написание велосипеда мы просто юзаем методы и довольствуется работой )
outoftime
║XLR8║
509 / 431 / 33
Регистрация: 25.07.2009
Сообщений: 2,295
14.12.2009, 00:30 #12
мудрые слова твои
perchik71
69 / 27 / 2
Регистрация: 08.08.2009
Сообщений: 60
14.12.2009, 00:30 #13
Цитата Сообщение от Андрейка Посмотреть сообщение
perchik71, парятся обычно чтобы узнать как работает структура , что такое указатели на след и пред элемент ( в данном случае) то есть программируя сам ты узнаешь почему так делается. а std::list используют чтобы не тратить время на написание велосипеда мы просто юзаем методы и довольствуется работой )
ыы))) спасибо))) я познал как это работает впринципе ))) но изобретать велосипед заново - с мну хватит)))
outoftime
║XLR8║
509 / 431 / 33
Регистрация: 25.07.2009
Сообщений: 2,295
14.12.2009, 00:34 #14
а иногда надо, где вы допустим возмете стек минимумов и максмимумов, который проводит добавление за О(1), узнать минимум за О(1), максимум за О(1), размер и т.д.?
только самому писать..
perchik71
69 / 27 / 2
Регистрация: 08.08.2009
Сообщений: 60
14.12.2009, 00:41 #15
Цитата Сообщение от outoftime Посмотреть сообщение
а иногда надо, где вы допустим возмете стек минимумов и максмимумов, который проводит добавление за О(1), узнать минимум за О(1), максимум за О(1), размер и т.д.?
только самому писать..
верно ... но я ща с отцом увлёкся редактором карт и там нужен список объектов ))) я лично создал структуру , а из неё при помощи list список )))
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
14.12.2009, 00:41
Привет! Вот еще темы с ответами:

Найти минимальный элемент каждой строки матрицы и поместить их на главной диагонали - C++
Двумерные массивы: 6)Найти минимальный элемент каждой строки квадратной матрицы X=( xi,k) и поместить их на главной диагонали, а...

Все слова из входного потока поместить в выходной поток с новой строки - C++
Здравствуйте уважаемые программисты помогите пожалуйста текст задачи: все слова из входного потока, помещать в выходной поток с новой...

Найти наименьшие элементы каждой строки квадратной матрицы и поместить их на главную диагональ - C++
где ошибка ? нужно найти малейшие элементы каждой строки квадратной матрицы и поместить их на главную диагональ а диагональные элементы...

Как поместить строки разной длинны в двумерный массив? (файловый ввод/вывод) - C++
Всем доброго времени суток! Есть файл с нескольким количеством строк и все эти строки разной длинны, как мне их поместить в двумерный...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
14.12.2009, 00:41
Ответ Создать тему
Опции темы

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