Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/11: Рейтинг темы: голосов - 11, средняя оценка - 5.00
В астрале
Эксперт С++
 Аватар для ForEveR
8049 / 4806 / 655
Регистрация: 24.06.2010
Сообщений: 10,562

Есть ли в классе строк или в алгоритмах разбиение строку на лексемы?

12.07.2010, 05:49. Показов 2161. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Собственно сабж, как говорится. Хотел переписать программу, которую делал с Си строками и массивом Си строк. Сделана она была не совсем правильно, ибо там логичнее было использовать двумерный массив, но все же. Вот переписал с использованием string. Только долго пришлось маяться. Искал какую-нибудь функцию, чтобы не переводить в Си строку для разбиения на слова. Есть ли такие стандартные функции в стл? П.С. собственно сама программа. Можно ли написать короче?

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
#include <iostream>
#include <cstring>
#include <string>
#include <vector>
#include <algorithm>
#include <cstdlib>
int main()
{
    std::string BaseString;
    std::vector<std::string> ArrString;
    std::cout<<"Enter string\n";
    std::getline(std::cin, BaseString);
    std::cout<<BaseString<<'\n';
    char*p;
    p=strtok((char*)BaseString.c_str(), ",. :!?");
    if(p)
    {
        ArrString.push_back(p);
        
    }
    while(p!=0)
    {
        p=strtok(0,",. :!?");
        if(p)
        {
            ArrString.push_back(p);
        }
    }
    std::vector<std::string>::iterator s=ArrString.begin();
    while(s!=ArrString.end())
    {
        std::cout<<*s<<'\n';
        s++;
    }
    int i=0;
    size_t max=ArrString[i].size();
    s=ArrString.begin();
    while(s!=ArrString.end())
    {
        if(ArrString[i].size()>max)
            max=ArrString[i].size();
        s++;
        i++;
    }
    i=0;
    s=ArrString.begin();
    while(s!=ArrString.end())
    {
        if(ArrString[i].size()==max)
            std::cout<<"Word with max lenght is: "<< *s <<'\n';
        s++;
        i++;
    }
    return 0;
}
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.07.2010, 05:49
Ответы с готовыми решениями:

Парсинг строк, разбиение строки на лексемы, регулярные выражения, разделители
недавно столкнулся с небольшой проблемой, необходимо выполнить казалось бы элементарную задачу - разделить строку, символы разделители...

Разбить строку на лексемы и вывести лексемы в обратном порядке.
Ребята, помогите. Получил такое задание: Напишите программу, которая вводит строку текста, разбивает ее на лексемы и выводит лексемы в...

Разбиение на лексемы
Нужно написать программу, запрашивающую строку текста, разбивающую ее на лексемы и выводящую лексемы в обратном порядке. Желательно си, не...

3
Эксперт С++
 Аватар для Nameless One
5828 / 3479 / 358
Регистрация: 08.02.2010
Сообщений: 7,448
12.07.2010, 06:36
Лучший ответ Сообщение было отмечено как решение

Решение

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
#include <iostream>
#include <fstream>
#include <deque>
#include <sstream>
#include <algorithm>
#include <iterator>
 
int main()
{
    std::string str("An international edition was released on August 9, 2005, published by Drakkar, with a different track listing");
    std::string punct(",!.:?");
    size_t index;
    //Меняем встретившиеся знаки препинания на пробелы
    while((index=str.find_first_of(punct))!=std::string::npos)
        str[index]=' ';
    std::stringstream ss(str);
    std::deque<std::string> dq;
    std::string temp;
    while(ss >> temp)
        dq.push_back(temp);
    std::copy(dq.begin(), dq.end(), std::ostream_iterator<std::string>(std::cout, "\n"));
    system("pause");
    return EXIT_SUCCESS;
}
Добавлено через 1 минуту
PS. Класс string имеет необходимые методы для работы со строками, так что в строки C переводить ничего не надо.
4
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
 Аватар для easybudda
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,973
12.07.2010, 12:26
Nameless One, я как-то даже тему создавал про то, как бы это стандартными методами в С++ строку по разным разделителям поделить, а вот поменять их на один единственный не догадался... Спасибо!
0
В астрале
Эксперт С++
 Аватар для ForEveR
8049 / 4806 / 655
Регистрация: 24.06.2010
Сообщений: 10,562
12.07.2010, 16:25  [ТС]
Спасибо большое.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.07.2010, 16:25
Помогаю со студенческими работами здесь

Разбиение кода на лексемы
Добрый день. Интересует такой вопрос. Какие средства могут помочь при написании программы анализа исходного кода java?Необходимо исходный...

Разбиение строки на лексемы
Вроде бы обычное, простое дело: разбить строку на лексемы, определённые &quot;подсветить&quot; и записать в выходной файл. Но возникли...

Split() и разбиение на лексемы
Доброго времени суток! Только подошел в изучению строк (String) и как понял, что в язык java они являются неизменяемыми объектами, но я бы...

System.String, C++ и разбиение на лексемы
Нужно выполнить задачу &quot;Дана строка состоящая из слов, разделенных пробелами (одним ил несколькими). Вывести строку содержащую эти же...

Чтение строки с файла, разбиение на лексемы и вывод по алфавиту
Долго мучился, и набросал вот такой код: #include&lt;stdio.h&gt; #include&lt;string.h&gt; #include&lt;conio.h&gt; #include&lt;stdlib.h&gt; ...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru