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

Приложение для вычисления значения арифметического выражения - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ алгоритмы и блок схемы http://www.cyberforum.ru/cpp-beginners/thread193633.html
в блок схеме должно все записываться на языке паскаль помогите,обычная блок схема
C++ Не понятно как работают функции bool isstrprint (const char s) { int i = -1, ls = strlen(s); bool rc = true; if (s != 0x00) { while (i <= ls && isprint((int)((unsigned char) s)) > 0); rc = (i ==... http://www.cyberforum.ru/cpp-beginners/thread193629.html
C++ факториал
Я только начал изучать С++ и вот столкнулся с проблемой: дано положительное число A>=10.Найти такое число k, что (k-1)!<=A<=k! заранее спасибо!
Ассемблерная вставка в Visual Studio C++
Есть программа, выполняющая шейкерную сортировку. Функция сортировки представляет собой ассемблерную вставку. Проблема в том что при возврате в главную функцию возникает исключение. Не пойму, в чем...
C++ Как из обычной структуры сделать хеш таблицу? http://www.cyberforum.ru/cpp-beginners/thread193612.html
У меня есть такая таблица: #ifndef DIPLOM_H #define DIPLOM_H #include <vector> using namespace std; struct T_Record { char name; //Фамилия, инициалы
C++ Информатика ! очень нужно Дано натуральное число k . Напечатать k-ую цифру (не число!) последовательности из идущих подряд чисел Фибоначчи. 112358132134... Необходимо построить программу так , чтобы она не накладывала... подробнее

Показать сообщение отдельно
frostua
0 / 0 / 0
Регистрация: 07.11.2011
Сообщений: 27
07.11.2011, 16:20
Ещё вариант:

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
#include <iostream>
#include <stdio.h>
#include <math.h>
//#include <iomanip>
using namespace std;
 
double count (int n, int m, char ar[])
{
    double rez;
    bool flag=0;
    int skobka=0;
    
        
    for (int i=n; i<m; i++){
        if (ar[i]=='(')skobka+=1;
        else if (ar[i]==')')skobka-=1;
        if (skobka==0){
        if (ar[i]=='+'){
            rez = count(n,i,ar)+ count(i+1,m,ar);//сложение
            flag=1;
            break;
        }
        if (ar[i]=='-'&&ar[i-1]!='('&&i!=0){
            rez = count(n,i,ar)- count(i+1,m,ar);//вычитание
            flag=1;
            break;
        }
        }
    }
    if (flag==0)
    {
        for (int i=n; i<m; i++){
            if (ar[i]=='(')skobka+=1;
            else if (ar[i]==')')skobka-=1;
            if (skobka==0){
            if (ar[i]=='*'){
            rez = count(n,i,ar)* count(i+1,m,ar);//умножение
            flag=1;
            break;
            }
            if (ar[i]=='/'){
            rez = count(n,i,ar)/ count(i+1,m,ar);//деление
            flag=1;
            break;
            }
            }
        }
    }
    if (flag==0)
    {
        for (int i=n; i<m; i++){
            if (ar[i]=='(')skobka+=1;
            else if (ar[i]==')')skobka-=1;
            if (skobka==0){
            if (ar[i]=='^'){
            rez = pow (count(n,i,ar), count(i+1,m,ar));//возведение в степень
            flag=1;
            break;
            }
            }
        }
    }
    if (flag==0)
        if (ar[n+1]=='('&&ar[n]=='-'&&(ar[n-1]=='('||n==0))return -count(n+1,m-1,ar);
        else if (ar[n]=='(')return count(n+1,m-1,ar);
        else if (ar[n-1]=='-'&&(ar[n-2]=='('||n-2==0))return -atof(&ar[n]);
        else return atof(&ar[n]);
    else return rez;
}
 
void main()
{
 
    cout<<fixed;
    while(1){
    char a[100];
    gets(a);    
    //cout<<setprecision(20);
    cout<<count (0, strlen (a), a)<<endl;
    }
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru