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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Ancloosee
0 / 0 / 0
Регистрация: 17.10.2015
Сообщений: 49
#1

Рекурсивный рисунок - C++

14.07.2016, 10:06. Просмотров 561. Ответов 9
Метки нет (Все метки)

Господа,добрый день.прошу вашей помощи так как сам уже и не успеваю ничего.Есть задание нарисовать вот такой рисунок
Рекурсивный рисунок
У меня уже мозг не варит,много еще чего нужно сделать.Вот прошу вашей помощи.Кто сможет помощь,код тот что набросал я вам скидываю.Помоги доделать задание

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
#include <windows.h>
#define u 5
 
void linetodxy(int dx, int dy);
int x, y;
 
void a(int i);
void b(int i);
void c(int i);
void d(int i);
 
 
/*  Declare Windows procedure  */
LRESULT CALLBACK WindowProcedure (HWND, UINT, WPARAM, LPARAM);
 
 
/*  Make the class name into a global variable  */
char szClassName[ ] = "Кривая Серпинского";
HINSTANCE hInstance;
 
HDC hdc; //создаём контекст устройства
PAINTSTRUCT ps; //создаём экземпляр структуры графического вывода
 
int WINAPI WinMain (HINSTANCE hThisInstance,
                    HINSTANCE hPrevInstance,
                    LPSTR lpszArgument,
                    int nFunsterStil)
 
{
    HWND hwnd;
    MSG messages;            /* Here messages to the application are saved */
    WNDCLASSEX wincl;        /* Data structure for the windowclass */
 
    /* The Window structure */
    wincl.hInstance = hThisInstance;
    wincl.lpszClassName = szClassName;
    wincl.lpfnWndProc = WindowProcedure;      /* This function is called by windows */
    wincl.style = CS_DBLCLKS;                 /* Catch double-clicks */
    wincl.cbSize = sizeof (WNDCLASSEX);
 
    /* Use default icon and mouse-pointer */
    wincl.hIcon = LoadIcon (NULL, IDI_APPLICATION);
    wincl.hIconSm = LoadIcon (NULL, IDI_APPLICATION);
    wincl.hCursor = LoadCursor (NULL, IDC_ARROW);
    wincl.lpszMenuName = NULL;                 /* No menu */
    wincl.cbClsExtra = 0;                      /* No extra bytes after the window class */
    wincl.cbWndExtra = 0;                      /* structure or the window instance */
    /* Use Windows's default color as the background of the window */
   // wincl.hbrBackground = (HBRUSH) COLOR_BACKGROUND;
    wincl.hbrBackground = CreateSolidBrush(RGB(255,255,255));
 
    /* Register the window class, and if it fails quit the program */
    if (!RegisterClassEx (&wincl))
        return 0;
    
    /* The class is registered, let's create the program*/
    hwnd = CreateWindowEx (
           0,                   /* Extended possibilites for variation */
           szClassName,         /* Classname */
           "Кривая Серпинского",       /* Title Text */
           WS_OVERLAPPEDWINDOW, /* default window */
           CW_USEDEFAULT,       /* Windows decides the position */
           CW_USEDEFAULT,       /* where the window ends up on the screen */
           544,                 /* The programs width */
           375,                 /* and height in pixels */
           HWND_DESKTOP,        /* The window is a child-window to desktop */
           NULL,                /* No menu */
           hThisInstance,       /* Program Instance handler */
           NULL                 /* No Window Creation data */
           );
 
 
 
    /* Make the window visible on the screen */
    ShowWindow (hwnd, nFunsterStil);
    UpdateWindow(hwnd);
    
    /* Run the message loop. It will run until GetMessage() returns 0 */
    while (GetMessage (&messages, NULL, 0, 0))
    {
        /* Translate virtual-key messages into character messages */
        TranslateMessage(&messages);
        /* Send message to WindowProcedure */
        DispatchMessage(&messages);
    }
 
    /* The program return-value is 0 - The value that PostQuitMessage() gave */
    return messages.wParam;
}
 
/*  This function is called by the Windows function DispatchMessage()  */
 
LRESULT CALLBACK WindowProcedure (HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam)
{
        
 
        
    switch (message)                  /* handle the messages */
    {
           
           case WM_CREATE:
 
//Поле типо мол "Введите порядок кривой: "
CreateWindow("static", "Введите порядок кривой: ", 
WS_CHILD|WS_VISIBLE|SS_LEFT|WS_EX_TRANSPARENT|WS_BORDER,
30,10,
300,30, 
hwnd, 0, hInstance, NULL);
 
//Поле для ввода порядка
CreateWindow("edit", NULL, WS_CHILD|WS_VISIBLE|ES_LEFT|WS_BORDER,
30,40,
100,30, 
hwnd, 0, hInstance, NULL);
 
//Кнопка начертить
CreateWindow("button", "Начертить", WS_CHILD|WS_VISIBLE|BS_DEFPUSHBUTTON,
50,180,
120,30, hwnd, 0, hInstance, NULL);
 
//Кнопка "Выход"
CreateWindow("button", "Выход", WS_CHILD|WS_VISIBLE|BS_DEFPUSHBUTTON,
175,180,
120,30, hwnd, 0, hInstance, NULL);
 
break;
           
          case WM_PAINT:
                
                hdc=BeginPaint(hwnd, &ps);
                //здесь можно вставить какие-нибудь функции рисования
                TextOut(hdc, 50,50, ".........................................!!!!", 26);
                POINT z;
                x=100, y=100;
 
                MoveToEx(hdc, x, y, NULL); //сделать текущими координаты x1, y1
 
                a(4);
                linetodxy(u, u);
           b(4);
                linetodxy(-u, u);
             c(4); 
                linetodxy(-u, -u);
                d(4); 
                linetodxy(u, -u);
 
                //обновляем окно
                ValidateRect(hwnd, NULL);
                //заканчиваем рисовать
                EndPaint(hwnd, &ps);                
                break;
           
           
        case WM_DESTROY:
            PostQuitMessage (0);       /* send a WM_QUIT to the message queue */
            break;
        default:                      /* for messages that we don't deal with */
            return DefWindowProc (hwnd, message, wParam, lParam);
    }
 
    return 0;
}
 
 
 
void linetodxy(int dx, int dy)
{
     x += dx;
     y += dy;
     LineTo(hdc, x, y);
}
 
void a(int i)
{
     if(i>0)
     {
            a(i-1); 
            linetodxy(0, 2*u);
           b(i-1);
           linetodxy(2*u,0);
            d(i-1);
            //linetodxy(2*u, 0);
            a(i-1);
            
     }
}
 
void b(int i)
{
     if(i>0)
     {
            b(i-1); 
            linetodxy(2 * u, 0);
            c(i-1); 
            linetodxy(0, -2 * u);
            a(i-1); 
            //linetodxy(2 * u, 0);
            b(i-1);
            
     }
}
 
void c(int i)
{
     if(i>0)
     {
            c(i-1);
            linetodxy(0, -2*u);
            d(i-1);
            linetodxy(-2*u, 0);
            b(i-1);
            linetodxy(0, -2*u);
            c(i-1);
     }
}
 
void d(int i)
{
     if(i>0)
     {
            d(i-1); 
            linetodxy(2 * u, 0);
            a(i-1);
            linetodxy(0,2*u);
            c(i-1);
            linetodxy(-2 * u, 0);
            d(i-1);
            linetodxy(0, 2*u);
     }
}

Всем спасибо
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.07.2016, 10:06
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Рекурсивный рисунок (C++):

Графический Рисунок(нужно составить рисунок на С++ в форме желтой звезды) - C++
нужно составить рисунок на С++ в форме желтой звезды

Рекурсивный минимум - C++
Здравствуйте Написать программу - Рекурсивный минимум Сначала скажите пожалуйста, что такое рекурсивный минимум ?

Рекурсивный метод - C++
Возможно, кто-то уже решал такую задачу как подпрограмму, или еще где. А, может, кто-то сходу видит, как это сделать. Динамическим...

рекурсивный алгоритм - C++
Уважаемые программисты! Есть задача: разработать рекурсивный алгоритм на с++ для нахождения самого длинного несамопересекающегося пути коня...

рекурсивный алгоритм - C++
В общем я уже намучился с этим заданием... Дело такое, алгоритм составлен, но не совсем такой, какой нужен #include &lt;iostream&gt; #include...

Рекурсивный алгоритм - C++
Даны натуральные числа &quot;N&quot; и &quot;M&quot; надо решить с помощью с++ не могу переставить с этим кодом с++ #include &lt;stdio.h&gt; #include...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Ferrari F1
14.07.2016, 12:25
  #2

Не по теме:

Как книга называется?

Ancloosee
0 / 0 / 0
Регистрация: 17.10.2015
Сообщений: 49
14.07.2016, 14:45  [ТС] #3
Не знаю,мне только эту фотку кинули
_Ivana
3048 / 1735 / 150
Регистрация: 01.03.2013
Сообщений: 4,921
Записей в блоге: 2
15.07.2016, 03:50 #4
Ем грибы, смотрю ковер (С)
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
#include "stdafx.h"
#include <windows.h>
#include <iostream>
using namespace std;
 
int x, y, d, p;
void l(HDC hDC, int i, int j) {x+=i*d/2; y+=j*d/2; LineTo(hDC, x, y); Sleep(p);}
void e(HDC hDC, int i, int j) {l(hDC, -i-j, i-j); l(hDC, i-j, i+j);}
 
void f(HDC hDC, int i, int j, unsigned int n) {
    if (n) {f(hDC,  i,  j, n-1); l(hDC, i+j, j-i);
            f(hDC,  j, -i, n-1); e(hDC, j, -i);
            f(hDC, -j,  i, n-1); l(hDC, i-j, i+j);
            f(hDC,  i,  j, n-1);}
}
int _tmain(int argc, _TCHAR* argv[]) {
    HWND hW = GetConsoleWindow();
    HDC hDC = GetDC(GetConsoleWindow());
    COLORREF colors[] = {RGB(255, 255, 255), RGB(255, 0, 0), RGB(255, 255, 0)
                        ,RGB(0, 255, 0), RGB(255, 0, 255), RGB(0, 0, 255)};
    setlocale(LC_ALL, "Russian");
    cout<<"Максимизируйте окно консоли, дабы все влезло\n"; system("pause");
    d=256; p=1000; int x0=300, y0=350, c=1;
    for(int i=1; i<=6; i++) {
        d/=2; p/=2; c=c*2+1; int h=d*c/2; x=x0-h+d; y=y0-h;
        HPEN pen = CreatePen(PS_SOLID, 1, colors[i-1]);
        SelectObject(hDC, pen);
        MoveToEx(hDC, x, y, NULL);
        f(hDC, 1, 1, i); e(hDC, 1, 1); f(hDC, -1, -1, i); e(hDC, -1, -1);
        DeleteObject(pen);
    }
    ReleaseDC(hW, hDC);
    system("pause"); return 0;
}
Миниатюры
Рекурсивный рисунок  
_Ivana
3048 / 1735 / 150
Регистрация: 01.03.2013
Сообщений: 4,921
Записей в блоге: 2
15.07.2016, 04:23 #5
...
Миниатюры
Рекурсивный рисунок   Рекурсивный рисунок  
_Ivana
3048 / 1735 / 150
Регистрация: 01.03.2013
Сообщений: 4,921
Записей в блоге: 2
15.07.2016, 06:26 #6
И еще четверка из десятков ковров:
Миниатюры
Рекурсивный рисунок   Рекурсивный рисунок   Рекурсивный рисунок  

Рекурсивный рисунок  
Ancloosee
0 / 0 / 0
Регистрация: 17.10.2015
Сообщений: 49
18.07.2016, 09:48  [ТС] #7
Спасибо больное,а мог бы обьяснить как оно роботает?какая переменная для чего
_Ivana
3048 / 1735 / 150
Регистрация: 01.03.2013
Сообщений: 4,921
Записей в блоге: 2
18.07.2016, 13:46 #8
Цитата Сообщение от Ancloosee Посмотреть сообщение
Спасибо больное
Здоровое "пожалуйста, обращайтесь если что"
Цитата Сообщение от Ancloosee Посмотреть сообщение
а мог бы обьяснить как оно роботает?какая переменная для чего
Очень просто - как робот роботоет! Видишь кокие ковры рисует!...
Ancloosee
0 / 0 / 0
Регистрация: 17.10.2015
Сообщений: 49
18.07.2016, 17:28  [ТС] #9
Хотелось бы немного подробнее объяснения,если не сложно
_Ivana
3048 / 1735 / 150
Регистрация: 01.03.2013
Сообщений: 4,921
Записей в блоге: 2
18.07.2016, 21:12 #10
А мне хотелось бы, чтобы на этом форуме банили халявщиков и была достойная администрация, уметь летать и вообще чтобы был мир во всем мире
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.07.2016, 21:12
Привет! Вот еще темы с ответами:

рекурсивный алгоритм - C++
задание было такое (я не раз обращался с ним уже): построить алгоритм вычисления значения аргумента exp(x) с точностью до &quot;эпсилон&quot; с...

Рекурсивный алгоритм - C++
помогите пожалуйста Представить в рекурсивный алгоритм Цикл пока ((proverka=1) и (k&gt;1) ) Если A &gt; A То Начало ...

Рекурсивный парсинг - C++
Есть формат на базе XML. 1. Файл начинается с &lt;?xml version=&quot;...&quot; encoding=&quot;ANSI...&quot;?&gt; 2. Поддерживается единственная кодировка только...

Рекурсивный способ и не рекурсивный способ - C++
Разработать программы по алгоритму с использованием рекурсивной функции и без использования рекурсивной функции. Задание. ...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
18.07.2016, 21:12
Ответ Создать тему
Опции темы

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