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

Перевести код с Python

30.05.2015, 12:20. Показов 2024. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
только вот не могу понять что делает операция return, после print ans, как дальше написать в c++ формате?

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
def gen(n, count, stack, ans):
    if count == n // 2 and len(stack) == 0:
        print ans
        return
    if count < n // 2:
        gen(n, count + 1, stack + '(', ans + '(')
        gen(n, count + 1, stack + '[', ans + '[')
    if len(stack) > 0:
        if stack[-1] == '(':
            gen(n, count, stack[:-1], ans + ')')
        if stack[-1] == '[':
            gen(n, count, stack[:-1], ans + ']')
 
N = int(input())
gen(N, 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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
// TrueBrackets.cpp: определяет точку входа для консольного приложения.
/////////////////////////////////////////////////////////////////////////////////////////
#include "stdafx.h"
#include <algorithm>
#include <iostream>
#include <iterator>
#include <set>
#include <string>
#include <vector>
#include <fstream>
 
using namespace std;
 
 
//Вывести все правильные скобочные выражения длиной N, состоящие из круглых и квадратных скобок.
//В первой строке находится единственное число N (1  ≤  N  ≤  14, N – чётное).
 
void TrueBrackets(int n, int count, string stack, string ans, vector<string>& VecAns) 
{
    if (count == n / 2 && stack.length() == 0)
    {
        VecAns.push_back(ans);
        return;
    }
    if (count < n /2)
    {
        TrueBrackets(n, count + 1, stack + '(', ans + '(', VecAns);
        TrueBrackets(n, count + 1, stack + '[', ans + '[', VecAns);
    }
    if (stack.length() > 0)
    {
        if (stack[stack.length() - 1] == '(')
            TrueBrackets(n, count, stack.erase(stack.find('('), 1), ans + ')', VecAns);
        if (stack[stack.length() - 1] == '[')
            TrueBrackets(n, count, stack.erase(stack.find('('), 1), ans + ']', VecAns);
    }
}
 
int main()
{
    setlocale(LC_ALL, "Russian");
    int LengthValue = 0;
    ifstream inputFile("input.txt");
    ofstream outputFile("output.txt");
    vector<string> VecAns;
    if (inputFile.is_open())
    {
        inputFile >> LengthValue;
        if ((LengthValue % 2 == 0) && ((LengthValue > 1) || (LengthValue <= 14)))
        {
            TrueBrackets(LengthValue, 0, "", "", VecAns);
            outputFile << "Все правильные скобочные выражения" << endl;
            std::copy(VecAns.begin(), VecAns.end(),
                ostream_iterator<vector<string>::value_type>(outputFile, "\n"));
        }
    }
    inputFile.close();
    outputFile.close();
    return 0;
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.05.2015, 12:20
Ответы с готовыми решениями:

Перевести код с Python на C++
Форумчане нужна помощь, надо перевести код из Python на C++ n = int(input()) data = + print(data) def...

Нужно перевести код с Python на С++
Всем доброго времени суток. Мне нужна помощь в переводе кода с Python на С++. Буду очень признателен если поможете. def section(k): if...

Перевести из Python в С++
from itertools import product print(*(''.join(it) for it in product('01', repeat=int(input()))), sep='\n') Нужно перевести данный...

6
2742 / 2341 / 620
Регистрация: 19.03.2012
Сообщений: 8,830
30.05.2015, 13:03
Цитата Сообщение от Kronos0041 Посмотреть сообщение
что делает операция return, после print ans
Она завершает работу функции, то есть просто выход из функции
0
2 / 2 / 1
Регистрация: 18.03.2014
Сообщений: 147
30.05.2015, 13:27  [ТС]
Цитата Сообщение от alex925 Посмотреть сообщение
Она завершает работу функции, то есть просто выход из функции
А как в c++ формат это перевести? Я также вставил return, но ничего не получается.

А вот именно как вот это перевести?

Python
1
2
3
4
        if stack[-1] == '(':
            gen(n, count, stack[:-1], ans + ')')
        if stack[-1] == '[':
            gen(n, count, stack[:-1], ans + ']')
0
2742 / 2341 / 620
Регистрация: 19.03.2012
Сообщений: 8,830
30.05.2015, 13:43
Цитата Сообщение от Kronos0041 Посмотреть сообщение
А как в c++ формат это перевести? Я также вставил return, но ничего не получается.
http://www.c-cpp.ru/books/vyhod-iz-funkcii
[ссылка на форум]
0
2 / 2 / 1
Регистрация: 18.03.2014
Сообщений: 147
30.05.2015, 20:54  [ТС]
C++
1
2
3
4
5
 if (count == n / 2 && stack.length() == 0)
    {
        VecAns.push_back(ans);
        return;
    }
вот так я и поставил, но оно почему-то не делает так как это происходит в питоне, вот я и задал вопрос.
0
923 / 639 / 198
Регистрация: 08.09.2013
Сообщений: 1,693
03.06.2015, 09:38
Лучший ответ Сообщение было отмечено Kronos0041 как решение

Решение

Цитата Сообщение от Kronos0041 Посмотреть сообщение
А как в c++ формат это перевести?
По образцу вашего Питоновского
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
#include <iostream>
#include <stack>
using namespace std;
 
void next (int n, string out= *new string, stack<char> st= *new stack<char>) {
  if (!n) {
    cout << out << endl;
    return;
  }
  if (st.size() < n) {
    st.push ('(');
    next (n-1, out+'(', st);
    st.top()= '[';
    next (n-1, out+'[', st);
    st.pop();
  }
  if (st.size()) {
    char c= st.top();
    st.pop();
    if (c == '(') next (n-1, out+')', st);
    else next (n-1, out+']', st);
  }
}
 
main() {
  int N;
  cin >> N;
  next (N);
}
Но мне подобный код на обычном Си приятнее писать, не вводя лишние сущности, будь они скрыты от программиста за семью печатями, как в Питоне, или демонстративно выставлены напоказ, как в Плюсах.
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 <stdio.h>
 
void next (int n, char *out) {
  char br[]= "()[]";
  int i, j, k;
  for (i= 0; i<n; i++) {
    if (out[i]) continue;
    for (j= i+1; j<n && !out[j]; j+=2) for (k=0; k<4; k+=2) {
      out[i]= br[k];
      out[j]= br[k+1];
      next (n, out);
      out[i]= out[j]= 0;
    }
    break;
  }
  if (i == n) printf ("%s\n", out);
}
 
main() {
  int N;
  char out[100]= {0};
  scanf ("%d", &N);
  next (N, out);
}
1
2 / 2 / 1
Регистрация: 18.03.2014
Сообщений: 147
11.06.2015, 11:49  [ТС]
Цитата Сообщение от gng Посмотреть сообщение
По образцу вашего Питоновского
а не мог бы еще помочь
вот мой с# код
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
 private void TrueBrackets(int length, string str, Stack <char> symbolStack, ref string[] vecAnswer, int count)
        {
            if (length == 0)
            {
                vecAnswer[count] = str;
                return;
                count++;
            }
            if (symbolStack.Count < length)
            {
                symbolStack.Push('(');
                TrueBrackets(length - 1, str + '(', symbolStack,ref vecAnswer, count);
                symbolStack.Pop();
                symbolStack.Push('[');
                TrueBrackets(length - 1, str + '[', symbolStack,ref vecAnswer, count);
                symbolStack.Pop();
            }
            if (symbolStack.Count != 0)
            {
                char c = symbolStack.Peek();
                symbolStack.Pop();
                if (c == '(') TrueBrackets(length - 1, str + ')', symbolStack,ref vecAnswer, count);
                else TrueBrackets(length - 1, str + ']', symbolStack, ref vecAnswer, count);
            }
        }
но там выбрасывается исключение, то что стек не заполнен, на строку 13
Почему он равен нулю, когда в с++, в строках 11 и 12 этот стек заполняется, а с# нет?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
if (st.size() < n) {
    st.push ('(');
    next (n-1, out+'(', st);
    st.top()= '[';
    next (n-1, out+'[', st);
    st.pop();
  }
  if (st.size()) {
    char c= st.top();
    st.pop();
    if (c == '(') next (n-1, out+')', st);
    else next (n-1, out+']', st);
  }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.06.2015, 11:49
Помогаю со студенческими работами здесь

Перевести с Python на С++
&lt;program&gt; ::= &lt;statement&gt; &lt;statement&gt; ::= &quot;if&quot; &lt;paren-expr&gt; &lt;statement&gt; | &quot;if&quot; &lt;paren-expr&gt; &lt;statement&gt; &quot;else&quot;...

Перевести программу с Python на С++
a=2000001 s=list(range(2,a)) s_sum=0 for i in s: if i**2&lt;a: k=0 while k&lt;len(s): if...

Visual c++ код перевести в gcc linux код
Ниже есть код. Нужно сделать так, что бы он компилировался и работал в линуксе(компиляция с помощью gcc). #include &quot;stdio.h&quot;...

перевести код на С++ или написать свой код
Задано предложение. Составить программу вывода на экран слов, в которых первая и последняя буквы совпадают. program Project1; ...

Перевести код программы Паскаля в код С++
В массиве Х (15) найти произведение и количество элементов расположенных между наибольшими и наименьшими элементами кто может перевести...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru