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

Формула, по которой можно вычислить время наступления Рагнарека - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ При выводе минимального элемента последовательности программа выводит слишком большое число http://www.cyberforum.ru/cpp-beginners/thread1232190.html
При выводе минимального элемента программа выводит слишком большое число. #include <iostream> using namespace std; int main() { setlocale(0,""); int maximum; float numbers, amount, average, maximal_element; float minimal_element; average = 0;
C++ Sentence. Записать число прописью Once upon a time in a land far far away, inhabited only by math students, Iva and Vedran were discussing self-explanatory sentences. A part of these sentences is exactly one number and it is equal to the total number of letters in the sentence. Some examples are: “This sentence has thirtyone letters.”, “Blah blah seventeen”. Little Jurica overheard his friends' conversation and decided to... http://www.cyberforum.ru/cpp-beginners/thread1232183.html
Определить является ли десятичная запись числа симметричной C++
Задание: код: #include<iostream> using namespace std; int main() { int n; cin>>n; cout<<((n/1000==n%10)&&(n/100/10==n%100%10))?1:37<<endl;; return 0;
Как правильно написать функцию push (положить в стек) C++
Здравствуйте, господа. Не могу сообразить, как правильно написать функцию push (положить в стек). Ткните меня носом пожалуйста. Всё остальное без ошибок. #include <conio.h> #include <iostream.h> struct Node { int left; Node *next; }; Node *beg = 0;
C++ Как происходит сортировка в данном блоке? http://www.cyberforum.ru/cpp-beginners/thread1232112.html
void Sort(char *text, int len, TCHAR* ptr, bool newFile) { char *info; int i=0,b=0; char loly; int lol; int j=0; char info1; info=(char*)malloc(len*sizeof(char)); strcpy(info,"");
C++ Перегрузка операций умножения и деления Создать класс "Строка текста с числами". Переопределить операции умножения и деления, так чтобы числа первой строки умножались и/или делились на числа второй строки, а текст между числами заменялся при умножении на более длинный, а при делении на более короткий. Например: "Сумма 484 из 112" / "Итог 11 для 4" = "Итог 44 из 28" "Сумма 484 из 112" * "Сумма 11 для 4" = "Сумма 5324 для 448" подробнее

Показать сообщение отдельно
Vtulhu
369 / 375 / 96
Регистрация: 12.08.2011
Сообщений: 1,610
23.07.2014, 08:54     Формула, по которой можно вычислить время наступления Рагнарека
Один я не понимаю, что и зачем вы там навертели в такой простой задаче? Видимо, изучение С++ необратимо захламляет мозг ООПом и прочими высокими абстракциями...
Задачка-то чисто алгоритмическая, хоть на С++, хоть на 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
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
#include "greatest.h"
 
void brackets(char* str)
{
    const char left[] = { '{', '[', '(' };
    const char right[] = { '}', ']', ')' };
    int i = -1;
    while( *str ) {
        if( *str == '(' ) {
            if( ++i == 3 ) { i = 0; }
            *str = left[i];
        } else if( *str == ')' ) {
            *str = right[i];
            if( --i == -1 ) { i = 2; }
        }
        ++str;
    }
}
 
TEST brackets_1()
{
    char s[] = "()";
    brackets(s);
    ASSERT_STR_EQ(s, "{}");
    PASS();
}
 
TEST brackets_2()
{
    char s[] = "(())";
    brackets(s);
    ASSERT_STR_EQ(s, "{[]}");
    PASS();
}
 
TEST brackets_3()
{
    char s[] = "((()))";
    brackets(s);
    ASSERT_STR_EQ(s, "{[()]}");
    PASS();
}
 
TEST brackets_4()
{
    char s[] = "(((())))";
    brackets(s);
    ASSERT_STR_EQ(s, "{[({})]}");
    PASS();
}
 
TEST brackets_5()
{
    char s[] = "x * (y + (z * (5 + 3)))";
    brackets(s);
    ASSERT_STR_EQ(s, "x * {y + [z * (5 + 3)]}");
    PASS();
}
 
TEST brackets_6()
{
    char s[] = "A + (B * ((C + D) + (N+K))) * (A + B) * (D * (B - (C + (E+K))))";
    brackets(s);
    ASSERT_STR_EQ(s, "A + {B * [(C + D) + (N+K)]} * {A + B} * {D * [B - (C + {E+K})]}");
    PASS();
}
 
SUITE(the_suite)
{
    RUN_TEST(brackets_1);
    RUN_TEST(brackets_2);
    RUN_TEST(brackets_3);
    RUN_TEST(brackets_4);
    RUN_TEST(brackets_5);
    RUN_TEST(brackets_6);
}
 
GREATEST_MAIN_DEFS();
 
int main(int argc, char **argv) {
    GREATEST_MAIN_BEGIN();      /* command-line arguments, initialization. */
    RUN_SUITE(the_suite);
    GREATEST_MAIN_END();        /* display results */
}
Код
C:\UTIL\tcc>tcc.exe -Wall -run brackets.c

* Suite the_suite:
......
6 tests - 6 pass, 0 fail, 0 skipped (1 ticks, 0.001 sec)

Total: 6 tests (15 ticks, 0.015 sec)
Pass: 6, fail: 0, skip: 0.
 
Текущее время: 16:55. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru