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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Определить количество членов последовательности, являющихся квадратами четных чисел http://www.cyberforum.ru/cpp-beginners/thread350336.html
Обьясните пожалуста как решить такую задачу: Даны целые положительные числа N, a1, ..., aN. Используя только элементарные арифметические операции (+, –, *, /), определить количество членов последовательности a1, ..., aN, являющихся квадратами четных чисел. Массивы не использовать.
C++ Разработать структуру с именем TRAIN Разработать класс для описанных ниже объектов. Включить в класс методы set (…), get(…), print (…). Определить свои методы для класса. Инициализацию производить в конструкторах и списках инициализации. 1. Train (поезд): Пункт назначения, Номер поезда, Время отправления, Число общих мест, Купейных, Плацкартных. Создать массив объектов. Вывести: a) список поездов, следующих до заданного... http://www.cyberforum.ru/cpp-beginners/thread350328.html
откорректировать output типа double C++
короче у меня #include <iostream> #include <cmath> using namespace std; int main() { long double n,m,a; cin>>n>>m>>a; long double o=ceil(n/a),O=ceil(m/a); if(o==1) cout<<O<<endl;
C++ Работа с портами
Здравствуйте,прошу о помощи в этой задаче. Разработать программу, обеспечивающую в непрерывном режиме считывание байта из порта 60h и вывод значения считанного байта на экран в: – десятичном формате, – шестнадцатеричном формате; – в символьной форме. Результат каждого считывания должен отображаться на новой строке. Нажатие на клавишу <ESC> (при этом из порта будет считано значение 1)...
C++ Определить, сколько и каких животных и людей будет у Максима через месяц http://www.cyberforum.ru/cpp-beginners/thread350304.html
У Максима х знакомых. Из них все четные - женского пола, а нечетные - животные. Те животные, индекс которых равен 3 - домашние. Из них животные, начинающиеся на гласную букву - парнокопытные, все остальные из домашних животных - кошачьи, а все остальные животные - рептилии. Определить, сколько и каких животных и людей будет у Максима через месяц, если все люди размножаются с геометрической...
C++ Стоит задача сравнение и подсчета символов строки. Стоит задача сравнение и подсчета символов строки. Получается, сравнить только всю строку. Подскажите пожалуйста, как сравнивать символы строки, а не всю строку целиком, но при этом программа выполняла бы туже функцию, что и ниже приведенная. То есть массив А инициализировать как А = {{'0','1','0','1'}, {'0','1','0','1'}, и т.д} и С как C = {{'0','0','0','0'}, {'0','0','0','1'}, и т.д} ... подробнее

Показать сообщение отдельно
AvengerAlive
5 / 5 / 0
Регистрация: 30.07.2011
Сообщений: 257
11.09.2011, 16:50  [ТС]     Вывести все правильные скобочные выражения длиной N, состоящие из круглых и квадратных скобок
valeriikozlov, а как это можно исправить?

Добавлено через 5 минут
Исправил так:
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
#include <iostream>
#include <cstring>
using namespace std;
 
int N;
 
void vokrug(char vir[], int type);
void right(char vir[], int type);
void left(char vir[], int type);
int main()
{
 char str[20];
 cin >> N;
 str[0]='\0';
 if (N==2) cout << "()" << endl << "[]" << endl;
 else
  {
   right(str,0);
   right(str,1);
  }
 return 0;
}
 
void vokrug(char vir[], int type)
{
 char str[20];
 int n=strlen(vir),i;
 if (n==N) return;
 for (i=0; i<n; i++) str[i+1]=vir[i];
 if (!type) str[0]='(',str[n+1]=')',str[n+2]='\0';
 else str[0]='[',str[n+1]=']',str[n+2]='\0';
 if (n==N-2) cout << str << endl;
 vokrug(str,0);
 vokrug(str,1);
 right(str,0);
 right(str,1);
 left(str,0);
 left(str,1);
}
 
void right(char vir[], int type)
{
 char str[20];
 int n=strlen(vir),i;
 if (n==N) return;
 for (i=0; i<n; i++) str[i]=vir[i];
 if (!type) str[n]='(',str[n+1]=')',str[n+2]='\0';
 else str[n]='[',str[n+1]=']',str[n+2]='\0';
 if (n==N-2) cout << str << endl;
 vokrug(str,0);
 vokrug(str,1);
 right(str,0);
 right(str,1);
}
 
void left(char vir[], int type)
{
 char str[20];
 int n=strlen(vir),i;
 if (n==N) return;
 for (i=0; i<n; i++) str[i+2]=vir[i];
 if (!type) str[0]='(',str[1]=')',str[n+2]='\0';
 else str[0]='[',str[1]=']',str[n+2]='\0';
 if (n==N-2) cout << str << endl;
 vokrug(str,0);
 vokrug(str,1);
 right(str,0);
 right(str,1);
}
Прошло 3 теста, 2 не проходит.
 
Текущее время: 19:43. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru