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

Лимит памяти - C++

Восстановить пароль Регистрация
 
Mihail_N
0 / 0 / 0
Регистрация: 06.08.2013
Сообщений: 4
12.06.2014, 13:06     Лимит памяти #1
На сайте е-олимп решал данную задачу:http://www.e-olimp.com/problems/6372 тут задача в том чтобы вывести правильную последовательность арифметических действий и посчитать ответ вот мой код:
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
97
98
99
100
101
102
103
104
105
106
107
108
#include <stdio.h>
#include <string>
#include <iostream>
#include <algorithm>
#include <vector>
#include <queue>
#include <set>
#include <sstream>
using namespace std;
 
int main()
{
   int n,k=0,t,a,i;
   char ci;
   vector<int>mas;
   string s1,s2,s3;
   cin>>n;
   for(int j=0;j<n;j++)
   {
       k=0;
       while(true)
       {
           t=false;
           cin.get(ci);
           if(ci=='\n')
               k++;
           if((k==2)&&(j==0))
               {a=atoi(s2.c_str()); mas.push_back(a); s2.clear();break;}
                   if((k==1)&&(j!=0))
               {a=atoi(s2.c_str()); mas.push_back(a); s2.clear();break;}
               
           if((ci=='+')||(ci=='*')||(ci=='/')||(ci=='-'))
               {s1.push_back(ci); t=true;}
           if(isdigit(ci))
               s2.push_back(ci);
           if(t)
           {a=atoi(s2.c_str()); mas.push_back(a); s2.clear();}
       }
       
       
           for(i=0;i<s1.size();i++)
               {
                   if(s1[i]=='*')
                   {
               s1.erase(i,1);
               mas[i]=mas[i]*mas[i+1];
               mas.erase(mas.begin() + i+1);
               s3.push_back('*');
               
               i=-1;
               if(mas.size()==1)
                   goto vixod;
               continue;
           }
                   if(s1[i]=='/')
                   {
               s1.erase(i,1);
               mas[i]=mas[i]/mas[i+1];
               mas.erase(mas.begin() + i+1);
               s3.push_back('/');
               
               i=-1;
               if(mas.size()==1)
                   goto vixod;
               continue;
           }
       }
 
 
           for( i=0;i<s1.size();i++)
               {
                   if(s1[i]=='+')
                   {
               s1.erase(i,1);
               mas[i]=mas[i]+mas[i+1];
               mas.erase(mas.begin() + i+1);
               s3.push_back('+');
               
               if(mas.size()==1)
                   goto vixod;
           }
                   if(s1[i]=='-')
                   {
               s1.erase(i,1);
               mas[i]=mas[i]-mas[i+1];
               mas.erase(mas.begin() + i+1);
               s3.push_back('-');
               
               if(mas.size()==1)
                   goto vixod;
           }
                   i=-1;
       }
vixod:
           cout<<"Case "<<"#"<<j+1<<": ";
           for(i=0;i<s3.size();i++)
           {
               cout<<s3[i]<<' ';
           }
           cout<<mas[0]<<endl;
           mas.clear();
           s3.clear();
           s2.clear();
           s1.clear();
 
   }
 return 0;
}
проблема в том что непонятно откуда на втором тесте вылазит лимит памяти..
http://www.e-olimp.com/solutions/1518387
я не могу понять почему так.. может у вас есть варианты?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.06.2014, 13:06     Лимит памяти
Посмотрите здесь:

C++ Как увеличить лимит на количество символов в консоли
C++ Builder Освобождение памяти
C++ Лимит
C++ Лимит памяти для решений задач
C++ Жор памяти
C++ Просрочен лимит времени
Утечка памяти C++
Лимит по времени C++
Как увеличить лимит объема текста в Memo в дизайне? C++ Builder
О памяти C++
C++ Лимит char в msvc
Счастливый билет (Лимит Времени) C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 04:14. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru