Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 0
Регистрация: 15.05.2017
Сообщений: 93

Создание формального языка по его вербальному описанию (С++)

11.10.2017, 18:04. Показов 1397. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Создать программу на С++, которая будет продуцировать цепочки(слова) в трехсимвольном алфавите с записью их в файл, причем длина L цепочек ограничена: L1(4)  L  L2(8) и для каждой цепочки, отобранной в файл, должно выполняться условие < A >. Общее количество цепочек в файле должно быть не более M(20).
Условие <А>- Содержит ровно два символа «с», заканчивается на «bс» и символы «а» и «b» не стоят рядом.
Помогите изменить в коде условие на выше написанное, спасибо заранее
Есть готовый код:
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
#include <iostream>
#include <fstream>
#include <string.h>
#define M 8
#define MV 18
#define CB '1'
#define CE '3'
using namespace std;
void GetNext(char* A);
void Next(char *A,int C);
void Clear(char* A);
int Owerflow(char* A);
void Show(char* A);
int Check(char* A);
char strtemp[8];
 
int main()
{
   char A[255]="1111";
   int k=0,cnt=0;
   ofstream fl;
   fl.open("gram.txt");
   fl<<"Содержит ровно два символа «а», заканчивается на «b» и символы «а» и «с» не стоят рядом L1=4, L2=8, M=18."<<endl;
 
   while (k<M && cnt<=MV){
 
    do {
       Show(A);
       if(Check(A)==0){cnt++;fl<<cnt<<". "<<strtemp<<endl;}
       if ( cnt>=MV) return 0;
       GetNext(A);
 
    }while (!Owerflow(A));
    Show(A);
    if(Check(A)==0){cnt++;fl<<cnt<<". "<<strtemp<<endl;}
   k++;
   if (k>M || cnt>=MV) return 0;
   for(int i=0;i<k+3;i++)A[i]='1';
   }
    fl.close();
    return 0;
}
 
void Clear(char* A){
for(int i=0;i<strlen(A);i++) A[i]=CE;
}
 
int Owerflow(char *A){
    int C = 0;
    for(int i=0;i<strlen(A);i++)
      if (A[i]== CE) C++;
    if(C == strlen(A))  return 1;
    else return 0;
}
 
void Next(char *A,int C){
  C--;
  if(A[C]==CE){
     A[C]=CB;
     C++;
     Next(A,C-1);
   }
   else A[C]++;
}
 
void GetNext(char* A){
if (Owerflow(A)) {
    A[0]++;
    Clear(A);
}
  else
    Next(A, strlen(A));
}
 
void Show(char* A){
//strtemp='';
for(int i=0;i<strlen(A);i++){
    if (A[i]=='1')strtemp[i]='a';
    if (A[i]=='2')strtemp[i]='b';
    if (A[i]=='3')strtemp[i]='c';
    }
cout<<strtemp<<' ';
}
 
int Check(char* A){
 int cntA=0,cntAC=0;
 for(int i=0;i<strlen(A);i++){
    if(A[i]=='1'){
        cntA++;
    if (A[i+1]=='3')cntAC++;
    }
    if(A[i]=='3' && A[i+1]=='1')cntAC++;
 }
 if(cntA==2 && cntAC==0 && A[strlen(A)-1]=='2')return 0;
 else return 1;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
11.10.2017, 18:04
Ответы с готовыми решениями:

Перевести описание структуры с формального языка на язык Си++
Здравствуйте. Очень нужна ваша помощь! Перевести ниже описанные структуры с формального языка на язык Си++ // Структура Рейс //...

Построение формального языка чисел 7-ричной с.с. цифры которых в неубывающем порядке
Необходимо построить грамматику формального языка чисел 7-ричной с.с. цифры которых в неубывающем порядке. Не совсем понимаю как...

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

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
11.10.2017, 18:04
Помогаю со студенческими работами здесь

Опознать фильм по его описанию
Здравствуйте! Страна: США (примерно 1995-2005г.) Муж с женой решили разводиться и продать дом. Чтобы привлечь покупателей они подговорили...

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

Как открыть кнопкой файл по его описанию (адресу)?
Имеется Еdit1, в котором указаны размещение и имя файла (изображение): С:\Имя папки\Имя файла.jpg Нужно открыть это изображение в...

Создание форма поиска по описанию (Access 2010)
есть база данных видео ролика, имеются таблицы видео, аудио, музыка, фото - в этих таблицах есть строка описание. не получается создать...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru