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

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 4.92
Sylar9
134 / 55 / 2
Регистрация: 04.09.2011
Сообщений: 1,952
Записей в блоге: 1
#1

Как разбить на лексемы - C++

14.07.2012, 18:10. Просмотров 1717. Ответов 1
Метки нет (Все метки)

Не могу понять как разбить на лексемы, помагите если не сложно Вот участок кода:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
#include <locale.h>
#include <math.h>
using namespace std;
int main()
{
    setlocale(LC_ALL, "Rus");
        int A, B;
    cout << "Введите A больше нуля + меньше десятки в девятой степени" << endl;
    cin >> A;
    if(A<0 || A>pow(10.0,9))
        cout << "Не соотвествует условию" << endl;
 
    cout << "Введите B больше нуля + меньше десятки в девятой степени" << endl;
    cin >> B;
    if(B<0 || B>pow(10.0,9))
        cout << "Не соотвествует условию" << endl;
 
 
 
    system("pause");
    return 0;
}
Добавлено через 10 минут
Нашел как в инети разбить на лексимы
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
#include <iostream>
#include <locale.h>
#include <math.h>
using namespace std;
int main()
{
    setlocale(LC_ALL, "Rus");
    char* A; 
    char* B;
    cout << "Введите A больше нуля + меньше десятки в девятой степени" << endl;
    cin >> A;
    if(A<0 || A>pow(10.0,9))
        cout << "Не соотвествует условию" << endl;
 
    cout << "Введите B больше нуля + меньше десятки в девятой степени" << endl;
    cin >> B;
    if(B<0 || B>pow(10.0,9))
        cout << "Не соотвествует условию" << endl;
    int i=0, j;
    // Для А
    char *tokenA[10];
    tokenA[i]=strtok(A, " ");
    i++;
    while (tokenA[i-1] != NULL) //Разбивает строку на слова и указатель на каждое слово заносит в массив  tokenPtr
    { 
        tokenA[i] = strtok(NULL, " ");
        i++;        
    }
    // Для B
    char *tokenB[10];
    tokenB[i]=strtok(B, " ");
    i++;
    while (tokenB[i-1] != NULL) //Разбивает строку на слова и указатель на каждое слово заносит в массив  tokenPtr
    { 
        tokenB[i] = strtok(NULL, " ");
        i++;        
    }
 
    system("pause");
    return 0;
}
теперь проблема как ввести тип char, что бы он только на цифры вводил

Добавлено через 5 минут
Вот сама задача
Задача 24
Вводится два числа A и B(A и B больше нуля + меньше десятки в девятой степени), определить состоят ли они из одних и тех же чисел.

Пример:

123 23122 = YES

44412 44512 = NO

STL нельзя
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.07.2012, 18:10
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Как разбить на лексемы (C++):

String разбить на лексемы - C++
есть пример которий записаний в string str1=(&quot;25+69-65*85/58+65*(12+36)+36&quot;) нужно его разбить на лексеми и записать в другой string str2 ...

Разбить строки на отдельные лексемы - C++
Прошу помощи для &quot;особо одаренных&quot;)). Учусь на программиста заочно (хотя в договоре вечернее). Теорию дают классно, но практики нет....

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

Посмотрите код! (используя функцию strtok, разбить телефонный номер формата (555) 555-5555, введенный как строку, на лексемы) - C++
Посмотрите код все правильно ли??? Задание звучит так, используя функцию strtok, разбить телефонный номер формата (555) 555-5555, введенный...

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

Как обратиться к лексемы в строке? - C++
Народ тут у меня проблема условие: дано ленту, пропуски считаем словами, а знаки препинания нет, последнее слово выделено запятой, нужно...

1
rangerx
1940 / 1549 / 141
Регистрация: 31.05.2009
Сообщений: 2,913
15.07.2012, 18:46 #2
Цитата Сообщение от Sylar9 Посмотреть сообщение
Вводится два числа A и B(A и B больше нуля + меньше десятки в девятой степени), определить состоят ли они из одних и тех же чисел.
Числа состоят из цифр, а не из чисел... Разбивать на лексемы тебе здесь ничего не нужно. Простейшее решение: заводишь два массива типа bool, по 10 элементов каждый, и инициализируешь их значением false. Затем, используя текущую цифру числа как индекс массива отмечаешь соответствующий элемент соответствующего массива значением true. После этого останется лишь проверить массивы на эквивалентность.

Добавлено через 1 минуту
Цитата Сообщение от Sylar9 Посмотреть сообщение
pow(10.0,9)
используй константу 1E+9 вместо pow, например
C++
1
2
const int min_value = 1;
const int max_value = 1E+9; // 10 ^ 9
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
15.07.2012, 18:46
Привет! Вот еще темы с ответами:

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

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

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

Разделить символьный массив на лексемы - C++
Нужно разделить символьный массив на лексемы. Новая лексема - от и до мат. знака (&quot;+&quot;, &quot;-&quot;, &quot;*&quot;,...


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

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

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