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

прямоугольник и овал - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ с++ и математика http://www.cyberforum.ru/cpp-beginners/thread750297.html
Здравствуйте. Как написать на си это?
C++ Поле класса - динамический массив Здравствуйте, друзья. Проверьте, пожалуйста, всё ли правильно написано (отсутствие сообщений об ошибках не исключает их присутствия). Цель - создать класс с указателем типа int. Этот поле использовать как динамический массив. Вот код: #include <iostream> #include <conio.h> using namespace std; const int SIZE = 3; http://www.cyberforum.ru/cpp-beginners/thread750287.html
Как записать 2x^4-3x^3+4x^2-5x-6 C++
Задача состоит в том, что бы записать уравнение 2x^4-3x^3+4x^2-5x-6 используя только операции умножение, вычисление, добавление и каждое из них можно использовать только четыре раза.
C++ Что за оператор GO TO NEXT?
Правильное ли утверждение: "действие оператора continue; в приведенных ниже примерах эквивалентно действию оператора go to next;". a)while (E) { S; ... continue; ... S; next: ; } b) do { S; ... continue; ... S; } while (E); next: ; ... . . . . . . Вот я не пойму что за оператор go to next? Кто может дать какую-нибудь инфу.
C++ Вывод данных из файла в массив http://www.cyberforum.ru/cpp-beginners/thread750254.html
Здравствуйте Уважаемые дамы и господа. Гуглил, читал но что-то никак не разберусь. Имеется тхт файлик Пример входного файла: 122235739687398670326509273096523096709239652386492036509 83475689723698723987569823759827385789237582378957239857893275.71 779077967857.8 Как загнать сие в массив тоесть загнать все подряд с пробелами разделающими строчки. Был бы благодарен ответам, а лучше...
C++ Библиотеки С/С++ для цифровой обработки сигналов Доброго времени суток! Хотел узнать, быть может кто-нибудь знает библиотеку/библиотеки С/С++ для цифровой обработки сигналов. Чтобы была возможность с их помощью реализовать следующие функции: корреляция, линейная и циклическая свертка, прямое/обратное преобразование Фурье. Сам пока искал нашел вот это: http://sourceforge.net/projects/kissfft/ Но быть может кто-нибудь знает библиотеки получше,... подробнее

Показать сообщение отдельно
asidorchenko
379 / 205 / 25
Регистрация: 09.04.2012
Сообщений: 635
03.01.2013, 07:24     прямоугольник и овал
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
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
#include <iostream>
#include <windows.h>
#include <windowsx.h>
#include <process.h>
#include <math.h>
#include <time.h>
#include <stdio.h>
#include <stdlib.h>
 
#define PI 3.14
 
#pragma comment (lib, "user32.lib")
#pragma comment (lib, "kernel32.lib")
#pragma comment (lib, "gdi32.lib")
 
 
HINSTANCE hInstance;
HINSTANCE hPrevInst;
LPSTR lpszArgs;
int nWinMode;
 
LRESULT CALLBACK WindowFunc(HWND, UINT, WPARAM, LPARAM);
 
 
class CoordinateSystem
{
 public:
  float center_x;
  float center_y;
  float mastab_x;
  float mastab_y;
  float x;
  float y;
 
  CoordinateSystem()
  {
   center_x = 200.0;
   center_y = 200.0;
   mastab_x = 20.0;
   mastab_y = 20.0;
   x = 2.0;
   y = 2.0;
  }
 
  void DrawCoordinateSystem(HDC hdc, int u)
  {
   int i , l;
   for(i = 0; i <= x*mastab_x; i++)
   {
    SetPixel(hdc, center_x + i, center_y, RGB(0,0,0));
    SetPixel(hdc, center_x - i, center_y, RGB(0,0,0));
   }
   for(i = 0; i <= y*mastab_y; i++)
   {
    SetPixel(hdc, center_x, center_y + i, RGB(0,0,0));
    SetPixel(hdc, center_x, center_y - i, RGB(0,0,0));
   }
   char buf[5];
   if (u==1)
   {
    // координатная сетка
    for(l=0;l<y;l++)
    {
     for(i = 0; i <= x*mastab_x ; i++)
     {
      SetPixel(hdc, center_x + i, center_y + mastab_y * ( l + 1 ), RGB(64,128,128));
      SetPixel(hdc, center_x - i, center_y + mastab_y * ( l + 1 ), RGB(64,128,128));
      SetPixel(hdc, center_x + i, center_y - mastab_y * ( l + 1 ), RGB(64,128,128));
      SetPixel(hdc, center_x - i, center_y - mastab_y * ( l + 1 ), RGB(64,128,128));
     }
    }
    for(l=0;l<x;l++)
    {
     for(i = 0; i <= y*mastab_y ; i++)
     {
      SetPixel(hdc, center_x + mastab_x * ( l + 1 ), center_y + i, RGB(64,128,128));
      SetPixel(hdc, center_x + mastab_x * ( l + 1 ), center_y - i, RGB(64,128,128));
      SetPixel(hdc, center_x - mastab_x * ( l + 1 ), center_y + i, RGB(64,128,128));
      SetPixel(hdc, center_x - mastab_x * ( l + 1 ), center_y - i, RGB(64,128,128));
     }
    }
   }
  }
 
};
 
class Recatngle : public CoordinateSystem
{
 public:
  float dx;
  float dy;
  COLORREF cr;
 
  Recatngle()
  {
 
  }
 
  void Draw(HDC hdc)
  {
   float x, y;
   static float cx = center_x;
   static float cy = center_y;
 
   int v_size = GetDeviceCaps(hdc, VERTRES);
   int h_size = GetDeviceCaps(hdc, HORZRES);
 
   int rn1, rn2, rn3;
 
   srand(time(NULL));
   rn1 = rand()%255;
   rn2 = rand()%255;
   rn3 = rand()%255;
   cr = RGB(rn1, rn2, rn3);
 
   if ( (cx + dx * mastab_x) >= 0 &&
        (cx + dx * mastab_x) <= h_size &&
        (cy + dy * mastab_y) >= 0 &&
        (cy + dy * mastab_y) <= v_size)
   {
     cx += 2.25;
   }
   else if (
        (cx + dx * mastab_x) >= h_size &&
        (cy + dy * mastab_y) >= 0 &&
        (cy + dy * mastab_y) <= v_size)
   {
     cy -= 2.25;
   }
   else if(
        (cx + dx * mastab_x) >= h_size &&
        (cy + dy * mastab_y) <= 0)
   {
     cx -= 2.25;
   }
   else if( (cx + dx * mastab_x) >= 0 &&
        (cx + dx * mastab_x) <= h_size &&
        (cy + dy * mastab_y) <= 0)
   {
     cx -= 2.25;
   }
   else if( (cx + dx * mastab_x) <= 0 &&
        (cy + dy * mastab_y) <= 0)
   {
     cy += 2.25;
   }
   else if( (cx + dx * mastab_x) <= 0 &&
        (cy + dy * mastab_y) >= 0 &&
        (cy + dy * mastab_y) <= v_size)
   {
     cy += 2.25;
   }
 
 
 
 
   for ( y = center_y + mastab_y * dy; y > center_y - mastab_y * dy; y--)
   {
     SetPixel(hdc, cx + mastab_x * dx, y, cr);
     SetPixel(hdc, cx - mastab_x * dx, y, cr);
   }
 
   for ( x = cx - mastab_x * dx; x < cx + mastab_x * dx; x++)
   {
     SetPixel(hdc, x, center_y + mastab_y * dy, cr);
     SetPixel(hdc, x, center_y - mastab_y * dy, cr);
   }
 
  }
};
 
class Ellips : public CoordinateSystem
{
 public:
  float a;
  float b;
  float r;
  COLORREF cr;
 
  Ellips()
  {
    srand(time(NULL));
    a = rand()%4;
    b = rand()%4;
    r = 4.0;
    cr = RGB(0, 255, 0);
  }
 
  void generate_color()
  {
   int rn1, rn2, rn3;
   srand(time(NULL));
   rn1 = rand()%255;
   rn2 = rand()%255;
   rn3 = rand()%255;
   cr = RGB(rn1, rn2, rn3);
  }
 
  void DrawE(HDC hdc)
  {
   float x, y;
 
   for(x = 0.0; x < a; x+=0.01)
   {
     y = b*b* sqrt(  1.0 - (x*x)/(a*a)  );
 
     SetPixel(hdc, center_x + mastab_x * x, center_y + mastab_y * y, cr);
     SetPixel(hdc, center_x + mastab_x * x, center_y - mastab_y * y, cr);
     SetPixel(hdc, center_x - mastab_x * x, center_y + mastab_y * y, cr);
     SetPixel(hdc, center_x - mastab_x * x, center_y - mastab_y * y, cr);
   }
  }
  void DrawE2(HDC hdc)
  {
   float x, y;
   static float cx = center_x;
   static float cy = center_y;
 
   srand(time(NULL));
   int v_size = GetDeviceCaps(hdc, VERTRES);
   int h_size = GetDeviceCaps(hdc, HORZRES);
 
   if ( (cx + r * mastab_x) >= 0 &&
        (cx + r * mastab_x) <= h_size &&
        (cy + r * mastab_y) >= 0 &&
        (cy + r * mastab_y) <= v_size)
   {
     cx += 2.25;
   }
   else if (
        (cx + r * mastab_x) >= h_size &&
        (cy + r * mastab_y) >= 0 &&
        (cy + r * mastab_y) <= v_size)
   {
     cy -= 2.25;
   }
   else if(
        (cx + r * mastab_x) >= h_size &&
        (cy + r * mastab_y) <= 0)
   {
     cx -= 2.25;
   }
   else if( (cx + r * mastab_x) >= 0 &&
        (cx + r * mastab_x) <= h_size &&
        (cy + r * mastab_y) <= 0)
   {
     cx -= 2.25;
   }
   else if( (cx + r * mastab_x) <= 0 &&
        (cy + r * mastab_y) <= 0)
   {
     cy += 2.25;
   }
   else if( (cx + r * mastab_x) <= 0 &&
        (cy + r * mastab_y) >= 0 &&
        (cy + r * mastab_y) <= v_size)
   {
     cy += 2.25;
   }
 
   generate_color();
 
   for(x = 0.0; x < r; x+=0.01)
   {
     y = sqrt(  r*r - x*x  );
 
     SetPixel(hdc, cx + mastab_x * x, cy + mastab_y * y, cr);
     SetPixel(hdc, cx + mastab_x * x, cy - mastab_y * y, cr);
     SetPixel(hdc, cx - mastab_x * x, cy + mastab_y * y, cr);
     SetPixel(hdc, cx - mastab_x * x, cy - mastab_y * y, cr);
   }
  }
};
 
class Renderer
{
 public:
   Ellips *e;
   Recatngle *r;
   int ellips_num;
   int v_size;
   int h_size;
 
   Renderer()
   {
     int i, rn;
     e = NULL;
     HDC hdc = GetDC(NULL);
     v_size = GetDeviceCaps(hdc, VERTRES);
     h_size = GetDeviceCaps(hdc, HORZRES);
     ReleaseDC(NULL, hdc);
     srand(time(NULL));
     rn = 3;//rand()%10;
     ellips_num = rn;
     e = new Ellips[rn];
     r = new Recatngle[rn];
     for(i = 0; i < rn; i++)
     {
       int y =  (rand()%5);
       e[i].r = y;
       e[i].center_x = h_size / 2.0;
       e[i].center_y = v_size -  (e[i].mastab_y) * y;
       r[i].dx = y;
       r[i].dy = y;
       r[i].center_x = h_size / 2.0;
       r[i].center_y = v_size -  (r[i].mastab_y) * (r[i].dy);
     }
   }
 
   ~Renderer()
   {
       delete []e;
       e = NULL;
   }
 
 
   void Draw(HDC hdc)
   {
     if (e != NULL)
     {
      int i;
      for(i = 0; i < ellips_num; i++)
      {
       e[i].DrawCoordinateSystem(hdc, 0);
       e[i].DrawE2(hdc);
       r[i].Draw(hdc);
      }
     }
   }
 
};
 
 
Renderer rh;
 
 
class exemple
{
    public:
        /*Главная функция приложения WinMain*/
        int  WINAPI WinMain(  HINSTANCE hInstance, HINSTANCE hPrevInst,
        LPSTR lpszArgs, int nWinMode) {
        char szWinName[ ]="MyWindow";      //Произвольное имя класса главного окна
        char szTitle[ ]="Программа";               //Произвольный заголовок окна
        MSG msg;                    //Структура msg типа MSG для получения сообщений Windows
        WNDCLASS wc;                                  //Структура wc типа WNDCLASS для задания
                                    //характеристик окна
        /*Заполнение структуры wc типа WNDCLASS для описания класса главного окна*/
        ZeroMemory(&wc,sizeof(wc));                             //Обнуление всех членов структуры wc
        wc.hInstance= hInstance;                                       // Дескриптор приложения
        wc.lpszClassName=szWinName;                           // Имя класса окна
        wc.lpfnWndProc=WindowFunc;                           // Определение оконной функции
        wc.style=0;                                                            // Стиль по умолчанию
        wc.hIcon=LoadIcon(NULL,IDI_APPLICATION);           //Стандартная пиктограмма
        wc.hCursor=LoadCursor(NULL,IDC_ARROW);              //Стандартный курсор мыши
        wc.hbrBackground=GetStockBrush(WHITE_BRUSH);         // Белый фон окна
        wc.lpszMenuName=NULL;                                  // Без меню
        wc.cbClsExtra=0;                                                  // Без дополнительной информации
        wc.cbWndExtra=0;                                                // Без дополнительной информации
        /*Регистрация класса главного окна*/
        if(!RegisterClass (&wc))                                         //Если класс окна не регистрируется
        {                                    // выводим сообщение и заканчиваем выполнение программы
        MessageBox (NULL,"Окно нерегестрируется","Ошибка",MB_OK);
        return 1;}                                                           // возвращаем код ошибки
        /*Создание главного окна и отображение его на мониторе*/
        HWND hwnd = CreateWindow (                           //Вызов функции API для создания ок-на
        szWinName,                                             // имя класса главного окна
                        szTitle,                                                       // заголовок окна
                        WS_OVERLAPPEDWINDOW,               // Стиль окна
                        100,                                                            // x-координата левого угла окна
                        100,                                                            // y-координата левого угла окна
                        500,                                                            // Ширина окна
                        500,                                                            // Высота окна
                        HWND_DESKTOP,                                  // Без родительского окна
                        NULL,                                                       // Без меню
                        hInstance,                                                  // Дескриптор приложения
                        NULL);                                                     // Без дополнительных аргументов
        ShowWindow (hwnd, SW_SHOWNORMAL);       //  Вызов функции API
                                            // для отображения окна
        /*Организация цикла обнаружения сообщений*/
        while(GetMessage(&msg,NULL,0,0))               // Если есть сообщение, передать его
                    // нашему приложению
        DispatchMessage(&msg);                               //и вызвать оконную функцию WindowFunc
        return 0;                                                     //После выхода из цикла вернуться в Windows
        }                                                                    //Конец функции WinMain
 
};
 
/*Оконная функция WindowFunc главного окна, вызываемая Windows и получающая в качестве параметра сообщение из очереди сообщений данного приложения */
LRESULT CALLBACK WindowFunc(HWND hwnd, UINT message,
                                WPARAM wParam, LPARAM lParam)  {
 switch(message) {                                      // выбор по значению сообщения (message)
  case WM_DESTROY:                           //При завершении приложения пользователем
  PostQuitMessage (0);                           //вызвать функцию API завершения приложения
  break;
 case WM_PAINT:
  {
  HDC hdc = GetDC(NULL);
  rh.Draw(hdc);
  ReleaseDC(hwnd, hdc);
  }
 break;
 default:                                    // Все сообщения, не обрабатываемые данной функцией,
                                            // направляются на обработку по умолчанию
  return DefWindowProc (hwnd,message,wParam,lParam);
 }                                                           //Конец оператора switch
 return 0;
}
 
 
int main(void)
{
 class exemple val;
 val.WinMain( hInstance,  hPrevInst, lpszArgs,  nWinMode);
}
 
Текущее время: 10:25. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru