Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
Егорка47
7 / 6 / 1
Регистрация: 26.10.2010
Сообщений: 249
#1

Где ошибка? - C++

26.12.2010, 18:56. Просмотров 635. Ответов 11
Метки нет (Все метки)

Программа не моя,но нужно запустить ее и показать что она работает. Но в том то и проблема что не запускается)
помогите определить где ошибка и как ее исправить!
ВС что то пишет мне..но я не понимаю что..

вот код:

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
#include "stdafx.h"
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <time.h>
#include <string.h>
 
bool check_signs(char a,char *signs)
{ 
int i;
for (i=0;i<strlen(signs);i++){
        if(a==signs[i])
        return false;
    }
    return true;
}
 
int* arr(int count)
{
    int *p,i;
    p=(int*)malloc(count*sizeof(int));
    srand((unsigned)time(NULL));
    for(i=0;i<count;i++)
        p[i]=rand();
    return p;
}
 
void  arr2(int count,int **p)
{
    int i;
    *p=(int*)malloc(count*sizeof(int));
    for(i=0;i<count;i++)
        (*p)[i]=rand();
}
 
void reverse(char *str1,char *signs)
{
    int i,n,a,b;
    char *str2,*tmp;
    str2=(char*)calloc(strlen(str1)+1,1);
    b=strlen(str1)-1; 
    do {
        tmp=(char*)calloc(strlen(str1),1);
        for(i=b;i>=0;i--) {
            if(check_signs(str1[i],signs)) {
                a=i;
                break;
            }
            else continue;
        }
        for(i=a;i>=0;i--) {
            if(check_signs(str1[i],signs)==0) {
                b=i+1;
                break;
            }
            else
                if((i==0)&(check_signs(str1[i],signs)!=0)) {
                    b=i;
                        break;
                }
                else continue;
        }
        n=a-b+1;
        memcpy(tmp,&str1[b],n);
        strcat(str2,tmp);
        strcat(str2," ");
        b=b-1;
        free(tmp);
    }
    while(i!=0);
    printf("\nNew string:\n\n");
    for (i=0;i<strlen(str2)-1;i++)
        printf("%c",*(str2+i));
    printf("\n");
}
 
void geometric_average(int *p,int str,int col)
{
    int i,j,negative;
    double product,root;
    for(i=0;i<str;i++) {
        for(j=0;j<col;j++) {
            if((i+2*j-5)%3==0)
                *(p+i*col+j)=-(245*i)%(10*j+124)+106;
            else
                *(p+i*col+j)=(245*i)%(10*j+124)-16;
        }
    }
    printf("\n");
    for(i=0;i<str;i++) {
        for(j=0;j<col;j++)
            printf("%d\t",*(p+i*col+j));
        printf("\n");
    }
    negative=0;
     product=1;
     for(i=0;i<str;i++)
          for(j=0;j<col;j++)
                if(*(p+i*col+j)<0){
                     product*=*(p+i*col+j);
                     negative++;
                }
                if((product<0)&(negative%2==0))
                     product=-product;
                if(negative!=0){
                     root=1.0/negative;
                     product=pow(product,root);
                     printf("\nGeometric average=%lf\n",product);
                }
                else{
                     printf("There are no negative elements\n");
                     return;
                }
}
 
double sine(double x)
{
    double y;
    y=sin(x);
    return y;
}
 
double square(double x)
{
    double y;
    y=x*x;
    return y;
}
 
double X(double x)
{
    double y;
    y=x;
    return y;
}
 
double cosine(double x)
{
    double y;
    y=cos(x);
    return y;
}
 
double exponent(double x)
{
    double y;
    y=exp(x);
    return y;
}
 
double square_root(double x)
{
    double y;
    y=sqrt(x);
    return y;
}
 
void task1()
{
    int count,i,*p;
    printf("Enter an amount of elements\n");
    scanf("%d",&count);
    printf("Array 1:\n\n");
    p=arr(count);
    for(i=0;i<count;i++)
        printf("%d\t",*(p+i));
    printf("\nArray 2:\n\n");
    arr2(count,&p);
    for(i=0;i<count;i++)
        printf("%d\t",*(p+i));
    printf("\n");
}
 
void task2()
{
    char st[255],*signs="., ;:-_!?";
    printf("\nEnter a string\n");
    fflush(stdin);
    gets(st);
    reverse(st,signs);
}
 
void task3()
{
    int *p,i,j,strings,col;
    printf("Enter an amount of strings and columns\n");
    scanf("%d%d",&strings,&col);
    p=(int*)malloc((strings*col)*sizeof(int));
    geometric_average(p,strings,col);    
}
 
void graph(double(*g)(double x),double min,double max,double step)
{
    double x,ymax,ymin,n,y[25];
    int i,j,count;
    for (i=0;i<80;i++)
        printf("_");
    j=0;
    for (x=min;x<=max;x+=step) {
        y[j]=g(x);
        j++;
    }
    count=j;
    ymin=y[0];
    ymax=y[0];
    for (j=0;j<count;j++) {
        if (y[j]<=ymin)
            ymin=y[j];
        if(y[j]>=ymax)
            ymax=y[j];
    }
 
    for (j=0;j<count;j++) {
        printf("\n|");
        n=1+(y[j]-ymin)/(ymax-ymin)*(70);
        for(i=ymin;i<n;i++)
            printf(" ");
        printf("*");
       }
    printf("\n");
    system("PAUSE");
}
 
void task4()
{
    double min,max,step;
    double (*menu4[])(double)={X,square,square_root,exponent,sine,cosine};
    int func;
    system("cls");
    printf("Vvedite min i max\n");
    scanf("%lf%lf",&min,&max);
    while(1) {
        system("cls");
        printf("1.y=x\n2.x*x\n3.square root from x\n4.e in degree x\n5.sin x\n6.cos x\n");
        scanf("%d",&func);
        system("cls");
        if(func==0) return;
        if(func==3) {
            if(max<0) {
                printf("Incorrect upper bound. Function definition range x>=0");
                return;
            }
            if(min<0) {
                printf("Your lower bound is negative.As the definition range of function is x>=0, as lower bound will be is taken x=0\n");
                min=0;
            }
        }
        step=(max-min)/25.0;
        graph(menu4[func-1],min,max,step);
    }
 
}
 
int main()
{
    int i;
    void (*a[])(void)={task1,task2,task3,task4};
    while(1){
        system("cls");
        printf("MENU\n\n1 - Dynamic creation of an array\n2 - Reverse of strings\n3 - Geometric average\n4 - Graph creation\n0 - Exit\n\nSelect the point of menu and press <Enter>\n-> ");
        scanf("%D",&i);
        system("cls");
        if(i==0) return 0;
        a[i-1]();
        system("PAUSE");
    }
    system("PAUSE");
    return 0;
}
P.S у предыдущего обладателя этой программы,рна работала. Я ниче не менял,так чтонедолжно быть серьезных ошибок)
можете скопиппастить(естественно те,кто имеет ВС) и проверить у себя в чем дело?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.12.2010, 18:56
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Где ошибка? (C++):

Вывести на экран количество слов где первая и последняя буквы одинаковы (не понимаю где ошибка) - C++
задан текст нужно вывести на экран количество слов где первая и последняя буквы одинаковы #include &lt;iostream&gt; #include &lt;conio.h&gt; ...

Подскажите, где может быть ошибка (структуры)? (скорее всего где-то амперсенд нужен, все вроде проверил) - C++
написать универсальный тип, который представляет точку на плоскости в координатах (х, у) и в полярных координатах. Написать функцию для...

Ошибка при компиляции. Где ошибка? (Работа с классом) - C++
Уважаемые форумчане! При компиляции проекта возникает ошибка &quot; undefined reference to `MeterNZiF::MeterNZiF()' &quot; на 7 строку приложения. ...

Укажите где ошибка (ошибка во время выполнения программы) - C++
Здравствуйте, помогите пожалуйста найти ошибки в коде которые возникаю при выполнении программы Картинка с ошибкой внизу поста. Код: ...

В чём ошибка.В коде там где коментарий там ошибка поучается. - C++
#include &lt;iostream&gt; #include &lt;Windows.h&gt; using namespace std; class CMyString{ char *pStr; public: ...

Где ошибка? - C++
#include &lt;iostream&gt; class Shape { public: Shape(double a = 0, double b = 0) { x = a; y = b;

11
besstiaa
94 / 94 / 7
Регистрация: 04.06.2010
Сообщений: 223
26.12.2010, 19:03 #2
Убрать #include "stdafx.h"
0
abyr
4 / 4 / 1
Регистрация: 23.12.2010
Сообщений: 27
26.12.2010, 19:06 #3
строка 261 - scanf("%D",&i); %D на %d поменяй
0
Егорка47
7 / 6 / 1
Регистрация: 26.10.2010
Сообщений: 249
26.12.2010, 19:10  [ТС] #4
поменял..
ниче не изменилось)пишет те же ошибки..

Добавлено через 27 секунд
Цитата Сообщение от besstiaa Посмотреть сообщение
Убрать #include "stdafx.h"
тоже не помогло..
0
Zakharov
2 / 2 / 0
Регистрация: 21.10.2010
Сообщений: 24
26.12.2010, 19:26 #5
А в какой среде запускаешь? У меня эта прога запустилась! В ВС 2008 проект консольный вин32 с предкомпилированным заголовком!
0
Егорка47
7 / 6 / 1
Регистрация: 26.10.2010
Сообщений: 249
26.12.2010, 19:29  [ТС] #6
вот только что попробовал в 2008 экспрессе. убрал первую строку и все ок!
в ВС 2010 все равно ошибку выдает..странно..
0
Zakharov
2 / 2 / 0
Регистрация: 21.10.2010
Сообщений: 24
26.12.2010, 19:35 #7
А ты файловым вводом-выводом дружиш?
0
Егорка47
7 / 6 / 1
Регистрация: 26.10.2010
Сообщений: 249
26.12.2010, 19:37  [ТС] #8
неа

Добавлено через 33 секунды
а может и дружу..просто не совсем понял,что вы написали))
0
Zakharov
2 / 2 / 0
Регистрация: 21.10.2010
Сообщений: 24
26.12.2010, 19:38 #9
Цитата Сообщение от Егорка47 Посмотреть сообщение
неа

Добавлено через 33 секунды
а может и дружу..просто не совсем понял,что вы написали))
та мне прогу задали а я никак не придумаю как решить!
Разместить текст в несколько столбцов, так чтоб n-е слово i-ой строки размещалось под n-им словом i+1-ой строки.
надо считать с файла а потом записать в файл новый выровненый текст!
0
Егорка47
7 / 6 / 1
Регистрация: 26.10.2010
Сообщений: 249
26.12.2010, 19:57  [ТС] #10
не..эт не ко мне)
создайте тему,может помогут более опытные)
0
Zakharov
2 / 2 / 0
Регистрация: 21.10.2010
Сообщений: 24
26.12.2010, 20:01 #11
Цитата Сообщение от Егорка47 Посмотреть сообщение
не..эт не ко мне)
создайте тему,может помогут более опытные)
Та я видел кто-то другой создавал но ему не помогли! я сам ему писал как делать, я то принцип понимаю а как реализовать не шарю нам эту тему толком не читали и не рассказывали!
0
Егорка47
7 / 6 / 1
Регистрация: 26.10.2010
Сообщений: 249
26.12.2010, 20:03  [ТС] #12
ну я уж так тем более не помогу..сам учусь пока по книге)
а эта программа - это задание по лабе,которое я нагло списал и пытаюсь понять)
0
26.12.2010, 20:03
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
26.12.2010, 20:03
Привет! Вот еще темы с ответами:

Где ошибка? - C++
Сейчас с товарищем сидим делаем лабу. У него работает у меня нет. Он мне скидывает скрин своего положения дел(кодим в QNX под VMWARE). На...

где ошибка - C++
#include &lt;iostream&gt; using namespace std; int main() { long p, k; cin &gt;&gt; p &gt;&gt; k; for (int i = 0; i &lt; k; i++) { ...

Где то ошибка - C++
Помогите вот текст программы не могу разобраться что да как. Все вроде правильно. #include &lt;stdio.h&gt; #include &lt;iostream&gt; #include...

Где ошибка? - C++
Программе подаются значения 15 переменных, она умножает каждое на 3 и делит на два. После все выводится. int main() { соut &lt;&lt;...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Опции темы

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