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

Большое потребление памяти приложением

21.05.2015, 13:40. Показов 1956. Ответов 22
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Как всегда нужна ваша помощь...
Почему происходит ошибка компиляции при увеличении числа N в строке "#define N=170".

Вот при таком значении N программа еще работает.
N отвечает за максимальное количество неизвестных в системе.
Но в требовании задача должна работать примерно до N = 1500.

В чем ошибка? Может просто комп не тянет?
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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
#include <iostream>
#include <vector>
#include <fstream>
#include <Cstring> 
#include <math.h>
#define N 170
using namespace std;
int n, k, m;
const double pi=3.1415926536;
double eps = 0.00001;
vector <int> st(10000);
 
ifstream in;  // Ïîòîê in áóäåì èñïîëüçîâàòü äëÿ ÷òåíèÿ
ofstream out; // Ïîòîê out áóäåì èñïîëüçîâàòü äëÿ çàïèñè
 
int a[100000][1500];
double b[10000][1500];
 
void glavelem( int k, double mas[][N+1], int n, int otv[] );
int j=0;
int gen(int pos)
{ 
    if (pos == 0) 
    {
        for (int i = k-1; i >= 0; i--)
            {
                 printf("%d ", st[i]);
                
                a[j][k-i-1] = st[i];
               
                out<<"a["<<j<<"]["<<k-i-1<<"]="<<st[i]<<" "; //-pravilnaya str
             }
             j++;
             printf("\n");
             out<<"\n";
        return 1;
    }
    
    int ans = 0;
    for (int i = 0; i < n; i++) 
    {
        st[pos-1] = i;
       
        ans += gen(pos-1);
       
    }
    return ans;
}
 
int main()
{           
     in.open("in.txt");
    out.open("out.txt");
    cout<<"Vvedite p, N, M posledovatelno cherez probel:"<<endl;
    cin>>n>>k>>m;            //k=N - drobnye koeff,  n=p - prostye chisla, m - celaya chast
    float nk1 = pow(n,k);
    
    int nk = nk1;
    
    printf("%d ",nk);
    printf("\n");
     for (int i1=0; i1<100000; i1++)
         for (int j1=0; j1<1500; j1++)
         a[i1][j1]=0;
         
    printf("Total: %d ", gen(k));
    printf("\n");
 
double sum[200000];
int i,j,w,k1;
double mas[N][N+1];
double mas1[N][N+1];
 for (int i1=0; i1<200000; i1++)
     sum[i1]=0;
 
 for (int i1=1; i1<nk; i1++)
{    for (int j1=0; j1<k; j1++) 
        { 
        sum[i1]+=a[i1][j1]/pow(2,j1+1);
//        sum[i1+nk-1]-=a[i1][j1]/pow(2,j1+1);
        }
    out<<"sum["<<i1<<"]="<<sum[i1];
    out<<"\n";
//    out<<"sum["<<i1+nk-1<<"]="<<sum[i1+nk-1];
//    out<<"\n";
}
       for (i=0; i<(nk*2-2)/2; i++)
          {
                 for (j=0; j<pow(n,k+m); j++)
                   {   
                       b[i][j] = cos(2*pi*sum[i+1]*j/nk);
                       b[i+(nk*2-2)/2][j] = sin(2*pi*sum[i+1]*j/nk);
                   }
           }
       for (i=0; i<(nk*2-2); i++)
           {   
               for (j=0; j<pow(n,k+m); j++)
                     out<<b[i][j]<<" ";
               out<<endl;
           }
////////////////////////////////////////////////////////////////////////////////
 
for (j=nk*2-2;j<=pow(n,k+m)-1;j++)
{   
     for (i=0;i<nk*2-2;i++)
         mas[i][nk*2-2]=b[i][j];
     for (i=0; i<nk*2-2; i++)
     for (w=0; w<nk*2-2; w++)
         mas[i][w]=b[i][w];
         
         for (i=0; i<nk*2-2; i++)
         for (w=0; w<nk*2-1; w++)
             if (fabs(mas[i][w])<eps) mas[i][w]=0;       // zamena na 0
             
         //vivod matricy: kotoruyu nado reshat
       out<<"\n";
       out<<"j="<<j<<endl;  
      for (i=0; i<nk*2-2; i++)
      {   
          for (w=0; w<nk*2-1; w++)
              out<<mas[i][w]<<" ";        
          out<<endl;
      }  
       
// METOD GAUSSA:         
  double x[N]; //---------Êîðíè ñèñòåìû
  int otv[N]; //-------Îòâå÷àåò çà ïîðÿäîê êîðíåé
 
   //----------Ñíà÷àëà âñå êîðíè ïî ïîðÿäêó
  for (i = 0; i < nk*2-2; i++)
    otv[i] = i;
  //--------------Ïðÿìîé õîä ìåòîäà Ãàóññà
  for (k1 = 0; k1 < nk*2-2; k1++)
  {
      glavelem(k1, mas, nk*2-2, otv); //------Óñòàíîâêà ãëàâíîãî ýëåìåíòà
    
      for (w = nk*2-2; w >= k1; w--)
           mas[k1][w] /= mas[k1][k1];
      for ( i = k1 + 1; i < nk*2-2; i++ )
      for ( w = nk*2-2; w >= k1; w-- )
        {
            mas[i][w] -= mas[k1][w] * mas[i][k1];
        }
  }
  //Îáðàòíûé õîä
  for ( i = 0; i < nk*2-2; i++ )
    x[i] = mas[i][nk*2-2];
    
  for ( i = nk*2-2 - 2; i >= 0; i-- )
    for ( w = i + 1; w < nk*2-2; w++ )
      x[i] -= x[w] * mas[i][w];
      
  //-----Âûâîä ðåçóëüòàòà
  for ( i = 0; i <nk*2-2; i++ )
    for ( w = 0; w < nk*2-2; w++ )
      if ( i == otv[w] )
      { //----Ðàññòàâëÿåì êîðíè ïîïîðÿäêó
        out<<"x["<<i<<"] = "<<x[w]<<endl;
      }     
  for (int r = nk*2-2; r <= pow(n,k+m)-1; r++)
      {
          x[r]=0;
          x[j]=1;
          out<<"x["<<r<<"] = "<<x[r]<<endl;
      }              
}
     in.close();
     out.close();
     
    system("PAUSE");
    return 0;
}
//----------------------------------------------
//Îïèñàíèå ôóíóöèè
//----------------------------------------------
void glavelem(int k2, double mas[][N+1], int n2, int otv[] )
{   // in.open("in.txt");
    // out.open("out.txt");
  int i2, j2, i_max = k2, j_max = k2;
  double temp;
  //Èùåì ìàêñèìàëüíûé ïî ìîäóëþ ýëåìåíò â ñòîëáöå
j2=k2;
  for ( i2 = j2; i2 < n2; i2++ )    
      if ( fabs( mas[i_max] [j_max] ) < fabs( mas[i2] [j2] ) )
          {
            i_max = i2;
            j_max = j2;
          }
    
  //Ïåðåñòàâëÿåì ñòðîêè
  for ( j2 = k2; j2 < n2 + 1; j2++ )
  {
    temp = mas[k2][j2];
    mas[k2][j2] = mas[i_max][j2];
    mas[i_max][j2] = temp;
  }
 
//  Ïåðåñòàâëÿåì ñòîëáöû
  for ( i2 = 0; i2 < n2; i2++ )
 {
    temp = mas[i2] [k2];
    mas[i2] [k2] = mas[i2] [j_max];
    mas[i2] [j_max] = temp;
 }
 
   //  Ó÷èòûâàåì èçìåíåíèå ïîðÿäêà êîðíåé
  i2 = otv[k2];
  otv[k2] = otv[j_max];
  otv[j_max] = i2;
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.05.2015, 13:40
Ответы с готовыми решениями:

Большое потребление памяти при вызове метода
Наблюдаю очень странное поведение Visual Studio 2008. В моём проекте на C# есть один метод, который содержит большое число кода (циклы,...

nginx+php-fpm debian - большое потребление памяти
Больше потребление cached памяти на сервере. (Графиг приложен). mysql, memcached вынесены на отдельный сервер. На этом сервере стоит...

Большое потребление оперативной памяти при долгой работе
Добрый день гуру программирования. Проблема у меня такая. Приложение потребляет слишком много оперативной памяти при долгой работе....

22
68 / 67 / 59
Регистрация: 14.07.2013
Сообщений: 251
21.05.2015, 13:54
У меня и при 170 уже жрет 600 мб оперативки. Вы бы это память динамически выделяли.
1
Заблокирован
21.05.2015, 14:14
Цитата Сообщение от victory19933 Посмотреть сообщение
#define N=170
Что такое N? Сейчас карты раскину. Может быть они что-нибудь скажут

Не по теме:

P.S. нужно переменным и константам давать осмысленные имена

0
15 / 15 / 4
Регистрация: 11.11.2014
Сообщений: 122
21.05.2015, 14:23
А можешь показать ошибку компилятора?
0
2 / 2 / 0
Регистрация: 24.04.2011
Сообщений: 70
21.05.2015, 15:10  [ТС]
Kapex,
Я использую Dev-cpp.
Выскакивает окошко "прекращена работа программы":
1)Искать решение в инете
2)Закрыть программу
3)Отладить
0
68 / 67 / 59
Регистрация: 14.07.2013
Сообщений: 251
21.05.2015, 15:25
Да еще это не ошибка компиляции, а ошибка выполнения.
0
15 / 15 / 4
Регистрация: 11.11.2014
Сообщений: 122
21.05.2015, 15:31
Не, в Dev-Cpp пока не пишу, пользуюсь vi. Неужели он не выдаёт код ошибки компиляции? Попробуйте жамкнуть "Поискать решение в Интернете"
0
2 / 2 / 0
Регистрация: 24.04.2011
Сообщений: 70
21.05.2015, 17:21  [ТС]
akaAxeL,
спасибо. ваша помощь с исп-ем динамической памяти немного помогла,теперь решается до 300 уравнений...))и ошибок выполнения нет.
Но неужели для компьютера такая сложная задача решить 500 или 1000 уравнений. не понимаю этого
0
15 / 15 / 4
Регистрация: 11.11.2014
Сообщений: 122
21.05.2015, 17:36
Кстати, интересный вопрос, почему оно такое придирчивое. Можете показать изменённый код? Посижу, покумекаю вечерком. И ещё, меня смущают строки 20 и 70 (конкретно переменная j). Оно так и должно быть?
1
68 / 67 / 59
Регистрация: 14.07.2013
Сообщений: 251
21.05.2015, 17:49
Попробуйте поменять тип сборки с Debug на Release, у меня на Release версии работает.
1
2 / 2 / 0
Регистрация: 24.04.2011
Сообщений: 70
21.05.2015, 18:48  [ТС]
Kapex,
в 20-й строке так и должно быть.
а в 70-й, не заметила, что второй раз объявляю. ну не ругается, да и ладно)
Я еще уменьшила количество данных,записываемых в файл и теперь решает более менее быстро до 1500 уравнений. мне больше и не надо=)
но вот кодик:
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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
#include <iostream>
#include <vector>
#include <fstream>
#include <Cstring> 
#include <math.h>
#define N 2000
 
using namespace std;
 
int n, k, m;
const double pi=3.1415926536;
double eps = 0.00001;
vector <int> st(10000);
 
ifstream in;  // Поток in будем использовать для чтения
ofstream out; // Поток out будем использовать для записи
 
int a[100000][1500];
double b[10000][1500];
 
void glavelem( int k, double** mas, int n, int* otv);
int j=0;
int gen(int pos)
{ 
    if (pos == 0) 
    {
        for (int i = k-1; i >= 0; i--)
            {
                 printf("%d ", st[i]);
                
                a[j][k-i-1] = st[i];
               
                out<<"a["<<j<<"]["<<k-i-1<<"]="<<st[i]<<" "; //-pravilnaya str
             }
             j++;
             printf("\n");
             out<<"\n";
        return 1;
    }
    
    int ans = 0;
    for (int i = 0; i < n; i++) 
    {
        st[pos-1] = i;
       
        ans += gen(pos-1);
       
    }
    return ans;
}
 
int main()
{           
     in.open("in.txt");
    out.open("out.txt");
    cout<<"Vvedite p, N, M posledovatelno cherez probel:"<<endl;
    cin>>n>>k>>m;            //k=N - drobnye koeff,  n=p - prostye chisla, m - celaya chast
    float nk1 = pow(n,k);
    
    int nk = nk1;
    
    printf("%d ",nk);
    printf("\n");
     for (int i1=0; i1<100000; i1++)
         for (int j1=0; j1<1500; j1++)
         a[i1][j1]=0;
         
    printf("Total: %d ", gen(k));
    printf("\n");
 
double sum[20000];
int i,j,w,k1;
//double mas[N][N+1];
//double mas1[N][N+1];
double** mas = new double*[N];
for (i = 0; i<N;i++)
mas[i] = new double[N+1];
///////////
 for (int i1=0; i1<20000; i1++)
     sum[i1]=0;
 
 for (int i1=1; i1<nk; i1++)
{    for (int j1=0; j1<k; j1++) 
        { 
        sum[i1]+=a[i1][j1]/pow(2,j1+1);
//        sum[i1+nk-1]-=a[i1][j1]/pow(2,j1+1);
        }
    out<<"sum["<<i1<<"]="<<sum[i1];
    out<<"\n";
//    out<<"sum["<<i1+nk-1<<"]="<<sum[i1+nk-1];
//    out<<"\n";
}
       for (i=0; i<(nk*2-2)/2; i++)
          {
                 for (j=0; j<pow(n,k+m); j++)
                   {   
                       b[i][j] = cos(2*pi*sum[i+1]*j/nk);
                       b[i+(nk*2-2)/2][j] = sin(2*pi*sum[i+1]*j/nk);
                   }
           }
       for (i=0; i<(nk*2-2); i++)
           {   
               for (j=0; j<pow(n,k+m); j++)
                     out<<b[i][j]<<" ";
               out<<endl;
           }
////////////////////////////////////////////////////////////////////////////////
double* x= new double[N];
int* otv = new int[N];
for (j=nk*2-2;j<=pow(n,k+m)-1;j++)
{   
     for (i=0;i<nk*2-2;i++)
         mas[i][nk*2-2]=b[i][j];
     for (i=0; i<nk*2-2; i++)
     for (w=0; w<nk*2-2; w++)
         mas[i][w]=b[i][w];
         
         for (i=0; i<nk*2-2; i++)
         for (w=0; w<nk*2-1; w++)
             if (fabs(mas[i][w])<eps) mas[i][w]=0;       // zamena na 0
             
         //vivod matricy: kotoruyu nado reshat
       out<<"\n";
       out<<"j="<<j<<endl;  
//      for (i=0; i<nk*2-2; i++)
//      {   
//          for (w=0; w<nk*2-1; w++)
//              out<<mas[i][w]<<" ";        
//          out<<endl;
//      }  
       
// METOD GAUSSA:         
//  double x[N]; //---------Корни системы
//  int otv[N]; //-------Отвечает за порядок корней
 
 
 
   //----------Сначала все корни по порядку
  for (i = 0; i < nk*2-2; i++)
    otv[i] = i;
  //--------------Прямой ход метода Гаусса
  for (k1 = 0; k1 < nk*2-2; k1++)
  {
      glavelem(k1, mas, nk*2-2, otv); //------Установка главного элемента
    
      for (w = nk*2-2; w >= k1; w--)
           mas[k1][w] /= mas[k1][k1];
      for ( i = k1 + 1; i < nk*2-2; i++ )
      for ( w = nk*2-2; w >= k1; w-- )
        {
            mas[i][w] -= mas[k1][w] * mas[i][k1];
        }
  }
  //Обратный ход
  for ( i = 0; i < nk*2-2; i++ )
    x[i] = mas[i][nk*2-2];
    
  for ( i = nk*2-2 - 2; i >= 0; i-- )
    for ( w = i + 1; w < nk*2-2; w++ )
      x[i] -= x[w] * mas[i][w];
      
  //-----Вывод результата
  for ( i = 0; i <nk*2-2; i++ )
    for ( w = 0; w < nk*2-2; w++ )
      if ( i == otv[w] )
      { //----Расставляем корни попорядку
        out<<"x["<<i<<"] = "<<x[w]<<endl;
      }     
  for (int r = nk*2-2; r <= pow(n,k+m)-1; r++)
      {
          x[r]=0;
          x[j]=1;
          out<<"x["<<r<<"] = "<<x[r]<<endl;
      }              
}
     in.close();
     out.close();
     
     
     delete[] mas;
     delete[] x;
     delete[] otv;
    system("PAUSE");
//    delete N;
    return 0;
}
//----------------------------------------------
//Описание фунуции
//----------------------------------------------
void glavelem(int k2, double** mas, int n2, int* otv)
{   // in.open("in.txt");
    // out.open("out.txt");
    
  int i2, j2, i_max = k2, j_max = k2;
  double temp;
  //Ищем максимальный по модулю элемент в столбце
j2=k2;
  for ( i2 = j2; i2 < n2; i2++ )    
      if ( fabs( mas[i_max] [j_max] ) < fabs( mas[i2] [j2] ) )
          {
            i_max = i2;
            j_max = j2;
          }
    
  //Переставляем строки
  for ( j2 = k2; j2 < n2 + 1; j2++ )
  {
    temp = mas[k2][j2];
    mas[k2][j2] = mas[i_max][j2];
    mas[i_max][j2] = temp;
  }
 
//  Переставляем столбцы
  for ( i2 = 0; i2 < n2; i2++ )
 {
    temp = mas[i2] [k2];
    mas[i2] [k2] = mas[i2] [j_max];
    mas[i2] [j_max] = temp;
 }
 
   //  Учитываем изменение порядка корней
  i2 = otv[k2];
  otv[k2] = otv[j_max];
  otv[j_max] = i2;
}
0
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,170
Записей в блоге: 10
21.05.2015, 19:15
Цитата Сообщение от akaAxeL Посмотреть сообщение
Вы бы это память динамически выделяли.
Каким образом это может помочь в данном случае?
0
15 / 15 / 4
Регистрация: 11.11.2014
Сообщений: 122
21.05.2015, 19:22
Если есть эксперты, то поправьте меня, пожалуйста, но я помню следующее (ну, если ты это и имелла в виду, то сорян)

Если ты объявляешь переменную за пределами main() и других функций (в начале файла), она автоматически становится видимой для всего, что находится в данном файле (что-то типа глобальной переменной для файла, глобальная область видимости). Второе объявление переменной с тем же именем внутрии функции main() скрывает глобальную переменную j (строка 22) и имеет локальную видимость, т.е. до окончания блока {} (по сути до конца main). Локальная переменная j работает внутри main(). Если ты уберёшь объявление в mаin(), тогда ты будешь изменять глобальную переменную j. Не уверен, что тебе этого хочется.

По поводу строчек 64 - 66 : если ты объявишь массив a вот так:
C++ (Qt)
1
int a[100000][1500] = {};
то компилятор сам проинициализирует массив нулями. Как никак экономия.

Строчку
C++ (Qt)
1
for (i=0; i<(nk*2-2)/2; i++)
замени на
C++ (Qt)
1
for (i=0; i<((nk*2-2)<<1); i++)
Может, сэкономишь пару минут

А вот это что за костыль?
C++ (Qt)
1
2
float nk1 = pow(n,k);
int nk = nk1;
1
265 / 165 / 56
Регистрация: 25.02.2015
Сообщений: 435
21.05.2015, 20:33
вот примерная оценка того, сколько может сожрать ваша программа:

C++
1
2
3
4
5
6
7
8
13  sizeof(int)    * 10000
18  sizeof(int)    * 100000 * 1500
19  sizeof(double) * 10000 * 1500
71  size(double)   * 20000
75  sizeof(ptr)    * N
77  sizeof(double) * N * (N + 1)
108 sizeof(int)    * N
109 sizeof(double) * N
первый столбик - номер строки из сообщения #11
считать лень, но на глазок видно, что дохрена.
0
15 / 15 / 4
Регистрация: 11.11.2014
Сообщений: 122
21.05.2015, 20:52
victory19933, кстати, если есть условие задачи, то есть шанс, что местные эксперты подскажут более быстрое и недорогое решение.
0
2 / 2 / 0
Регистрация: 24.04.2011
Сообщений: 70
21.05.2015, 22:26  [ТС]
советы по усовершенствованию - учту! про костыль отдельно. Вылазила ошибка при возведении в степень, выдавал ответ на 1 меньше...(например при возведении 5 в квадрат - выдавал 24), пока не сделала так.
0
15 / 15 / 4
Регистрация: 11.11.2014
Сообщений: 122
21.05.2015, 22:38
victory19933, да, не, фигня, не может быть такого, чтобы функция pow так работала. Это какие-то сказочные чудеса.
0
 Аватар для Хулиган
88 / 83 / 21
Регистрация: 08.08.2012
Сообщений: 737
21.05.2015, 23:04
Цитата Сообщение от Kapex Посмотреть сообщение
Строчку
Код C++ (QT)
1
for (i=0; i<(nk*2-2)/2; i++)
замени на
Код C++ (QT)
1
for (i=0; i<((nk*2-2)<<1); i++)
Может, сэкономишь пару минут
компилятор оптимизирует код и данные ,для проверки условия, не будут заново считаться при каждой итерации цикла и кстати это умножение, а не деление на 2
C++
1
()<<1;
0
15 / 15 / 4
Регистрация: 11.11.2014
Сообщений: 122
21.05.2015, 23:15
Хулиган, по поводу компилятора вообще ничего не могу сказать. Но, мне кажется побитовая операция должна работать быстрее, тем более при внешнем цикле в 20 тысяч может сэкономить какое-нибудь время.

А с 2 ошибочка действительно вышла, деление будет ()>>1

victory19933, может стоит поиграться с опциями компилятора. Там должно найтись то, что ускорит скомпилированный код.
0
 Аватар для Хулиган
88 / 83 / 21
Регистрация: 08.08.2012
Сообщений: 737
21.05.2015, 23:31
Цитата Сообщение от Kapex Посмотреть сообщение
по поводу компилятора вообще ничего не могу сказать. Но, мне кажется побитовая операция должна работать быстрее, тем более при внешнем цикле в 20 тысяч может сэкономить какое-нибудь время.
почему вы думаете, что умнее компилятора? он сам заменит ваше деление на сдвиг. Сдвиги используются для неких манипуляций с битами.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.05.2015, 23:31
Помогаю со студенческими работами здесь

Большое потребление ОЗУ, как можно хоть немного уменьшить потребление ?
Может есть какие нибудь советы или еще что нибудь ? В основном приложение работает библиотекой jsoup и все. Парится с инета но там не...

Большое потребление STM8S-discovery.
Здравствуй, сообщество. Пытался сейчас замерить потребление платы STM8S-DISCOVERY в Halt режиме и обнаружил какие-то странности. Платка...

Большое потребление ОЗУ конкретной игрой
Доброго времени суток. Проблема вот в чём: у меня ноутбук на ОС windows 7 (3 гб ОЗУ) , игры более менее тянет, но вот одна игра в процессах...

Очень большое потребление ОЗУ не понятно чем
После получаса работы за компьютером происходит &quot;взлёт&quot; оперативки, иногда и пассиве может такое быть. Трудоёмких задач не открывал. В...

Большое потребление ресурсов процессора WebBrowser и WebSocket JS
Добрый день. Подключаюсь к серверу через веб сокет таким образом: public void Connect(WebBrowser wb) { ...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru