С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.80/25: Рейтинг темы: голосов - 25, средняя оценка - 4.80
 Аватар для lolopolosko
1354 / 315 / 6
Регистрация: 21.11.2009
Сообщений: 992

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

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

Студворк — интернет-сервис помощи студентам
Подскажите или покажите на примере как поместить в список несколько строк...?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.12.2009, 20:57
Ответы с готовыми решениями:

Функция: поместить все цифры в начало строки, а буквы в конец строки
Дана строка, состоящая из букв и цифр. Написать функцию, которая помещает все цифры в начало строки, а буквы в конец строки (без...

Запросить у пользователя последовательность чисел и поместить её в список
Условие задачи: Пользователь вводит числа, и эти числа записываются в список. Когда пользователь вводит q то программа останавливается и...

Поместить данные в линейный односвязный список отсортированными по возрастанию
Здравствуйте, несколько дней бьюсь над задачей, нужна помощь! Задание: Разработайте программу, которая вводит с клавиатуры ввода...

27
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
13.12.2009, 21:01
Мейн
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;
    }
};

сам попросил
1
 Аватар для lolopolosko
1354 / 315 / 6
Регистрация: 21.11.2009
Сообщений: 992
13.12.2009, 21:53  [ТС]
ща попробую)))

Добавлено через 11 минут
все норм...чучуть изминил и пошло)а то стандартный шаблон list не хочет почемуто принимать строки у меня
0
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
13.12.2009, 21:57
напиши свой, что тебе мешает?
0
 Аватар для lolopolosko
1354 / 315 / 6
Регистрация: 21.11.2009
Сообщений: 992
13.12.2009, 22:22  [ТС]
я просто ща здаю лабораторные роботы...а свой шаблон list я уже писал но только он односвязный или как там говорят ....этот шаблон тоже очень похож на список....ток возвращает даные как стек
0
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
13.12.2009, 23:57
тебе линковку надо делать не с первого на последующий а с последующего на первый, и держать еще один указатель на последний элемент, тогда когда ты его пройдешь все будет в прямой последовательности..
NULL <- 1 <- 2 <- ... <- n - list (begin <- ... <- end)
1 -> 2 -> 3 -> ... -> NULL - stack (begin -> ... -> end)
0
 Аватар для perchik71
70 / 28 / 3
Регистрация: 08.08.2009
Сообщений: 60
14.12.2009, 00:08
Цитата Сообщение от 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 записаны
1
425 / 229 / 87
Регистрация: 25.03.2009
Сообщений: 744
14.12.2009, 00:12
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
1
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
14.12.2009, 00:14
Андрейка, так ведь ему на лабу свой надо))
0
 Аватар для perchik71
70 / 28 / 3
Регистрация: 08.08.2009
Сообщений: 60
14.12.2009, 00:22
Цитата Сообщение от outoftime Посмотреть сообщение
Андрейка, так ведь ему на лабу свой надо))
Оо
писал давно правд .... и больше 2 раз в приложении я не смог использовать поэтому освоился с list зачём париться над тем что уже придумали ))))
0
425 / 229 / 87
Регистрация: 25.03.2009
Сообщений: 744
14.12.2009, 00:27
perchik71, парятся обычно чтобы узнать как работает структура , что такое указатели на след и пред элемент ( в данном случае) то есть программируя сам ты узнаешь почему так делается. а std::list используют чтобы не тратить время на написание велосипеда мы просто юзаем методы и довольствуется работой )
2
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
14.12.2009, 00:30
мудрые слова твои
0
 Аватар для perchik71
70 / 28 / 3
Регистрация: 08.08.2009
Сообщений: 60
14.12.2009, 00:30
Цитата Сообщение от Андрейка Посмотреть сообщение
perchik71, парятся обычно чтобы узнать как работает структура , что такое указатели на след и пред элемент ( в данном случае) то есть программируя сам ты узнаешь почему так делается. а std::list используют чтобы не тратить время на написание велосипеда мы просто юзаем методы и довольствуется работой )
ыы))) спасибо))) я познал как это работает впринципе ))) но изобретать велосипед заново - с мну хватит)))
0
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
14.12.2009, 00:34
а иногда надо, где вы допустим возмете стек минимумов и максмимумов, который проводит добавление за О(1), узнать минимум за О(1), максимум за О(1), размер и т.д.?
только самому писать..
0
 Аватар для perchik71
70 / 28 / 3
Регистрация: 08.08.2009
Сообщений: 60
14.12.2009, 00:41
Цитата Сообщение от outoftime Посмотреть сообщение
а иногда надо, где вы допустим возмете стек минимумов и максмимумов, который проводит добавление за О(1), узнать минимум за О(1), максимум за О(1), размер и т.д.?
только самому писать..
верно ... но я ща с отцом увлёкся редактором карт и там нужен список объектов ))) я лично создал структуру , а из неё при помощи list список )))
0
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
14.12.2009, 08:27
каких карт? топографических?
0
 Аватар для lolopolosko
1354 / 315 / 6
Регистрация: 21.11.2009
Сообщений: 992
14.12.2009, 10:09  [ТС]
ггг)))круто)))дошли уже до карт)))на самом деле мне нужно создать шаблончик список для помещение в него наперед неизвестное количество строк..введения строк должно быть с стандартоного вводу(cin cout gets puts). ну и в этом списке найти самую длинную строку...

Все это я сделал но лаба у меня по Потокам...я не знаю что здесь использовать чтобы задача вышла как надо....

вот кидаю вам исходник свой если надо

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
#include<iostream>
#include<string>
using namespace std;
 
template <typename T>
struct node
{
    T inf;
    node<T>* next;
};
 
template <typename T>
class mLIST
{
private:
    node<T>* head;
public:
    mLIST(){head =0;}
    ~mLIST(){}
    
    void push(T &val)
    {
        node<T>* tmp = new node<T>;
        tmp->inf = val;
        tmp->next = head;
        head = tmp;
    }
    T pop()
    {
        T res = head->inf;
        node<T>* tmp = head;
        head = head->next;
        delete tmp;
        return res;
    }
 
    bool empty(){return (head == NULL);}
 
    
};
 
 
int main()
{
    mLIST<string> s;
    string str;
    string cha,cha1;
    for(int i=0;i<5;i++){
        cin>>str;
        s.push(str);}
    cout << "STRI4KU:\n";
    cha=s.pop();
    while (!s.empty()){
        cha1=s.pop();
    if(cha1.length()>cha.length())cha=cha1;
    }     
    cout<<"Naibilsha stri4ka="<<cha;
 
 
    system("PAUSE");
    return 0;
 
}
может подскажете что здесь использовать(Потоковый вывод) чтобы выводить например не через стандартную функцию...
C++
1
cout<<"Naibilsha stri4ka="<<cha;
написать например
C++
1
ostream operator<<
но мне кажется это выйдет перегрузка
0
 Аватар для perchik71
70 / 28 / 3
Регистрация: 08.08.2009
Сообщений: 60
14.12.2009, 15:29
Цитата Сообщение от outoftime Посмотреть сообщение
каких карт? топографических?
Графических - которые в Играх 3D )

Добавлено через 33 минуты
ггг)))круто)))дошли уже до карт)))на самом деле мне нужно создать шаблончик список для помещение в него наперед неизвестное количество строк..введения строк должно быть с стандартоного вводу(cin cout gets puts). ну и в этом списке найти самую длинную строку...


-----------------------------------------------

Я ща напишу те как я вижу твою задачу с комментами

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
#include <windows.h>    // Ну тут понятно
#include <iostream>    // все твои (cin,out,gets,puts)
#include <list.h>           // Класс список
struct SpisokStr
{
    char Str[MAX_PATH];  //буффер с неизвестной пока длинной можно и char buf[]="";
    int size;                    // длина строки
    SpisokStr(const char* str) { strcpy(Str,str); size=strlen(str); }
};
void main()
{
    list<SpisokStr*> SS; //список
    int kol;  // кол-во строк
    char buf[MAX_PATH];  // буффер
    cout<<"Ну скоко строк-то???))): "; // вывод текста
    cin>>kol; // ввод числа
    while(kol)
    {
        cout<<"Ну пиши ;): "; // вывод текста
        cin>>buf; // ввод строки
        SS.push_back(new SpisokStr(const_cast<const char*>(buf))); //запись в список
    }
    for(list<SpisokStr*>::iterator it=map_obj.begin();it!=map_obj.end();++it)
    { cout<<"Длинна: "; cout<<(*it)->size; cout<<'\n'; } // получение длин 
    delete SpisokStr; // освободить память
    cin>>buf; // типа пауза жми Enter и выход....
}
можно написать короче но я сделал так чтоб структура знала не только текст но и её длинну
Идея моя понятна?
Можно и пронумеровать )))

Добавлено через 10 минут
И никакой перегрузки не будет ofstream те только результат в файл закатает
1
 Аватар для lolopolosko
1354 / 315 / 6
Регистрация: 21.11.2009
Сообщений: 992
14.12.2009, 16:26  [ТС]
Идея понятно....но только при компиляции очень много ошибок...я так понял ты писал прогу на скорую руку...
постараюсь переделать...
0
 Аватар для perchik71
70 / 28 / 3
Регистрация: 08.08.2009
Сообщений: 60
14.12.2009, 16:31
Цитата Сообщение от lolopolosko Посмотреть сообщение
Идея понятно....но только при компиляции очень много ошибок...я так понял ты писал прогу на скорую руку...
постараюсь переделать...
ща я глян __)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.12.2009, 16:31
Помогаю со студенческими работами здесь

Отсортировать массив данных о студентах, поместить его в двунаправленный список
заполнить динамический массив данных о студентах. Отсортировать его по факультетам. Отсортированный массив поместить в двунаправленный...

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

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

Выбрать все простые числа из списка и поместить их в список типа очередь
end не однозначный символ, как исправить то народ? задание: Создать двусвязный список целых чисел. Выбрать все простые числа и...

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


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru