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

Не работает функция atoi - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Матрица произвольных размеров http://www.cyberforum.ru/cpp-beginners/thread38055.html
решил создать класс, который формировать двумерный массив произвольного размера создаю класс - файл "ttt.h": #ifndef TTT_H #define TTT_H class ttt { public: ttt(int=3,int=3); void setArea();//присвоение эл-там массива нулевые значения
C++ Созданние формы Здравствуйте, Я создал форму в С++6, и есть необходимость прикрепить ее в web приложении написанной на php, как правильно это сделать(сконвертировать и т.п)? http://www.cyberforum.ru/cpp-beginners/thread38042.html
Не могу прервать процедуру по таймеру C++
Здравствуйте. Не могу разобраться с запуском-остановкой таймера на С++. Сделал диалоговое окно, по нажатию ОК запускаю таймер, запускаю какую-либо функцию, и таймер должен её прервать. Хотя бы опередить :) void C_123_Dlg::OnBnClickedOk() { m_OutText="старт"; //поле Edit UpdateData (FALSE); m_nTimer = SetTimer(0, 100, 0); //что значит первый ноль в параметрах? for (i=0;...
C++ В тексте найти количество слов, начинающихся и заканчивающихся гласной русской буквой
В тексте найти количество слов, начинающихся и заканчивающихся гласной русской буквой. буду очень благодарен за помощь!
C++ Проблемы с Ati2dvag.dll http://www.cyberforum.ru/cpp-beginners/thread38021.html
когда роботаю в среде С++ выбиваэт синий екран и там много чего написано,типа проблемы с Ati2dvag.dll! што ето может быть? ошыбка появляэться после нескольки минут роботы в програме!
C++ Структуры в функциях привет вот у меня есть такой код struct box { char nme; int vol; }; void sin ( box cn); void cot (box ct); подробнее

Показать сообщение отдельно
WWW
0 / 0 / 0
Регистрация: 03.06.2009
Сообщений: 5
03.06.2009, 15:14     Не работает функция atoi
Здравствуйте! Прошу помочь. Даю код программы, что не так с функцией atoi ?
Программа рисует кривую Гильберта, i - порядок кривой, мне надо, чтобы пользователь вводил в графическом режиме порядок, но он не высвечивался на экране, а просто сразу рисовалась кривая
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
#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
#include<math.h>
#include<dos.h>
#include <graphics.h>
 
#define del 30 //задержка
 
//Округление вещественных чисел до целых
int round (float a)
{
    return (int) floor (a+0.5);
}
 
//Прототипы функций, используемых до определения
void G2(int,int); void G3(int,int);
 
// Прорисовка линий-связок
//0-вверх, 1-вниз, 2- вправо, 3-влево
void L0 (int n)
{
    linerel (0,-n);
}
void L1 (int n)
{
    linerel (0,n);
}
void L2 (int n)
{
    linerel (n,0);
}
void L3 (int n)
{
    linerel (-n,0);
}
 
//Прорисовка кривых Гильберта остальных порядков, цифры обозначают те же направления
void G0 (int i, int n) //i - порядок кривой Гильберта
{
    if (i>0)
    {
    G2(i-1,n);    L0(n);
    G0(i-1,n);    L2(n);
    G0(i-1,n);    L1(n);
    G3(i-1,n);    delay(del);
    }
}
void G1 (int i,int n) //i - порядок кривой Гильберта
{
    if (i>0)
    {
    G3(i-1,n);    L1(n);
    G1(i-1,n);    L3(n);
    G1(i-1,n);    L0(n);
    G2(i-1,n);    delay(del);
    }
}
void G2 (int i, int n) //i - порядок кривой Гильберта
{
    if (i>0)
    {
    G0(i-1,n);    L2(n);
    G2(i-1,n);    L0(n);
    G2(i-1,n);    L3(n);
    G1(i-1,n);    delay(del);
    }
}
void G3 (int i, int n) //i - порядок кривой Гильберта
{
    if (i>0)
    {
    G1(i-1,n);    L3(n);
    G3(i-1,n);    L1(n);
    G3(i-1,n);    L2(n);
    G0(i-1,n);    delay(del);
    }
}
 
 
 void main()
{
    clrscr();
 
 
    /* request auto detection */
   int gdriver = DETECT, gmode, errorcode;
   int x,y;
   int n, i,x0, y0,Hscr,Wscr,s, S;
   float SPr = 80;
 
 
 
       /* initialize graphics mode */
       initgraph(&gdriver, &gmode, "");
 
    Hscr = getmaxy();//Высота экрана
    Wscr = getmaxx();//Ширина экрана
 
    //Приветственное сообщение
    setcolor (4);
    rectangle(10,10,630,470);
    setcolor (3);
    rectangle(25,25,615,455);
    setcolor (14) ;
    outtextxy (150,220, "This program draws the Gilbert's curve ");
    setcolor (3);
    outtextxy (150, 300, "Press any key to continue ");
    getch();
    clrscr();
 
    setbkcolor(0);
 
    Again:setfillstyle(1,0);
    bar (0,0, 639,479);
    setcolor (14);
    //Вводим исходные данные
    do
    {
       outtextxy (30,30,"Vvedite porjadok krivoi ot 1 do 8");
       char ch = getch();                                             // ВОТ ЗДЕСЬ Я ЧТО-ТО НАПОРТАЧИЛА :-)
       i = atoi ( ch);
 
    }
    while (i<1 || i>8);
    clrscr();
 
    setfillstyle(1,0);
    bar (0,0, 639,479);
    setcolor (4);
    rectangle(10,10,630,470);
    setcolor (3);
    rectangle(25,25,615,455);
 
    //Находим сторону квадрата, в который будет вписана кривая и длину каждого деления кривой
    S = round( SPr/100 * Hscr);
    n = round( S/ (pow(2,i) - 1));
 
    //Находим координаты начальной точки кривой.
 
    x0=Wscr/2 - S/2;
    y0=Hscr/2 + S/2;
 
    //Курсор устанавливаем в начальную точку
    moveto(x0, y0);
 
    setcolor (12);
 
    //Рисуем соответствующий вариант кривой Гильберта 
    G0(i,n);
 
    getch();
 
    setfillstyle(1,0);
    rectangle(1,1,639,479);
    bar(1,1,639,479);
    setcolor (4);
    rectangle(10,10,630,470);
    setcolor (3);
    rectangle(25,25,615,455);
    setcolor (14);
 
    outtextxy(220,235,"[1] -> Continue");
    outtextxy(220,245,"[2] -> Exit");
 
    char ch = getch();
 
    if(ch == '1')  // если продолжить
    {
        goto Again;
    }
 
    else
    closegraph();
 
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 23:31. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru