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

Выводит всегда последнюю букву "я" - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Придумайте (и реализуйте) вид образцов http://www.cyberforum.ru/cpp-beginners/thread895339.html
Использование библиотеки ввода-вывода языка С++ 12. Придумайте (и реализуйте) вид образцов, которые намного лучше чем в 11. 11. Разработайте и реализуйте операцию ввода по сопоставлению с образцом. Должна быть возможность попробовать сопоставить со вводом несколько образцов для нахождения наиболее близкого к образцу. Можно было бы вывести класс ввода по образцу из istream.(примеры образцов...
C++ Вывод строки: в нижнем регистре / в верхнем регистре / в HEX формате Использование библиотеки ввода-вывода языка С++ 14. Напишите программу которая будет просить ввести строку символов , после этого он печатает её на экране 1) все буквы в нижнем регистре , 2) все буквы в большом регистре , 3) все числа в строке выводить в HEX формате , 4) вывод с заменой всех пробелов на символ # http://www.cyberforum.ru/cpp-beginners/thread895336.html
Класс должен вывести всю строку форматировано на экран и без пробелов C++
23. Перегрузите операцию >> для класса , прегруженная функция должна передать строку из случайных символов ,а класс должен вывести всю строку форматировано на экран и без пробелов
C++ Динамический массив строк (вставить строку с номером к)
Написал программу,задача была сформировать динамический массив и вставить строку с номером к.(вводить пользователь).Никак не пойму как производится сдвиг,пытаюсь сдвинуть но происходит лишь замена элемента, подскажите пожалуйста как сдвигаются элементы.Вот код: #include <iostream> #include <string> #include <windows.h> using namespace std; void main() { SetConsoleCP(1251);...
C++ Неправильные includies http://www.cyberforum.ru/cpp-beginners/thread895318.html
Вот дана эта программа, к примеру: Файл cOther.h #ifndef _OTHER_H_ #define _OTHER_H class cOther { public: int one, two, three;
C++ Нужно выполнить лабораторную, пожалуйста. К зачёту не допускают 1.Проверьте, есть ли в слове приставка "при" или "пре". 2.Вставьте в слове после "кас" букву "а", если ее там нет. 3.Удалите из слова все буквы, совпадающие с последней буквой Заранее спасибо. подробнее

Показать сообщение отдельно
ilizard
0 / 0 / 0
Регистрация: 03.12.2012
Сообщений: 50
08.06.2013, 19:19     Выводит всегда последнюю букву "я"
Какие бы я преобразования не делала, в конце всегда выводиться "я". Не знаю, почему.
Вот кодна функцию mal_sсhet можно не смотреть)
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
//#include "stdafx.h"
#include <cstdlib>
#include <iostream>
#include <conio.h>
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#define MIN -32768
#define MAX 32767
 
using namespace std;
 
int ch;
char expression[100];
char a[20], b[20], p[40],otvet, ex_str[20]; 
    int i, j, shet=0, one=0, k=0, two=0, flag=0, m[5], p_n=0, n=20, flag1=0, z=0,kol_skob=0, q=0, l=0, n2, skob[20];
    float c[20],otv; 
 
int error() {
    return -1;
}
     
float mal_schet (int one, int two, char * a) 
{
  
     for (i = 0; i < n; i++)
     {
        c[i] = 0;
        b[i] = '0';
     }
     
     j=-1;       
 
     if (a[one] == '-') one++;                      //anee ia?aia ?enei io?eoaoaeuii
 
     for (i = one; i <= two; i++)     
     {    
          if (a[i] - '0' >= 0 && a[i] - '0' <=9)   //i?iaa?ea ia oeo?o
          {
             j++;
             c[j]=a[i]-'0';  
 
             if(((a[i+1]-'0')>=0) && ((a[i+1]-'0')<=9))
             {
                   i++;j++;
                   while (a[i]-'0'>=0 && a[i]-'0'<=9)
                   {
                         c[j]=a[i]-'0';
                         c[j-1] = c[j-1]*10 + c[j];
                         i++;
                   }
                   j--; i--;
             }
                
           }
          else
          {
              if (a[i]>=42 && a[i] <= 47)          //i?iaa?ea ia ciae
              {
                  if (a[i+1]>=42 && a[i+1] <= 47) 
                  {
                     flag=1;
                     break;
                  }
                  b[j+1]=a[i];
              }
              else
              {
                  if (a[i]!=32) 
                  {
                       flag = 1;
                        break;
                   }
               } 
          }
      } 
 
              
     if (a[one-1]=='-') 
        c[0]=0-c[0];   
 
 
 
     for (i=1;i<=n;i++) 
     {    
         if (b[i]==',' || b[i]=='.') 
         {
              c[i]=c[i-1]+ c[i]/pow(10,(int)(log10(c[i])+1));
              for (j=i;j<=n;j++)
              { 
                  c[j-1]=c[j];
                  b[j]=b[j+1];
              }
              n--; i--;
         }
     }
         
 
     for (i=1;i<=n;i++) 
     {    
         if (b[i]=='*') 
         {
              c[i]=c[i-1]*c[i];
             
              for (j=i;j<=n;j++)
              { 
                   c[j-1]=c[j];
                   b[j]=b[j+1];
              }
          
              n--; i--;
         }
 
         if (b[i]=='/' || b[i]=='|') 
         {
            c[i]=c[i-1]/c[i];
            
            for (j=i;j<=n;j++)
            {
               c[j-1]=c[j];
               b[j]=b[j+1];
            }
            
            n--;i--;
         }
      }
      
      for (i=1;i<=n;i++) 
      {    
           if (b[i]=='+') 
           {
                c[i]=c[i-1]+c[i];
                for (j=i;j<=n;j++)
                {
                    c[j-1]=c[j];
                    b[j]=b[j+1];
                } 
                
                n--;i--;
           }
 
            if (b[i]=='-') 
            {
                 c[i]=c[i-1]-c[i];
                 
                 for (j=i;j<=n;j++)
                 {
                     c[j-1]=c[j];
                     b[j]=b[j+1];
                 } 
                 
                 n--;i--;
            }
       }
 
       if (flag==0) 
            otv = c[0];
       else 
            error();
 
 
       return (otv);
} 
    
void readExp(FILE *in, FILE *out) {
    for (int i = 0; i < 100; i++) {
        expression[i] = 0;
    }
    int count = 0;
    int countStr = 0;
    
    for (int i = 0; i > -1; i++) {
        if (!feof(in)) {
            ch = getc(in);
            if (ch != '\n') {
            if (ch != ']') {
                expression[count] = ch;
                count++;
            } else {
                if (getc(in) == ']' && getc(in) == ']'){    
                    i = -2;
                } else {
                i=-2;
                    error();
                }
            }
            } else {
            countStr++;
            }
        } else {
        i=-2;
            error();
        }
    }
    
    float k = (mal_schet(1, (count - 1), expression) + 1);
    fprintf(out, "%f", k);
    for (int i = 0; i < countStr; i++) {
        putc('\n', out);
        }
 
}
 
void readChar(FILE *in, FILE *out) { 
    while (!feof(in)) {
        ch = getc(in);
        
            if (ch == '[') {
                if (getc(in) == '[' && getc(in) == '[') {
                    readExp(in, out);
                    } else {
                        error();
                        }
            } else {
                putc(ch, out);
            }
    }
    
}           
 
 
 
 
int main(int argc, char *argv[]) {
    const char in[] = "in.txt";
    const char out[] = "out.txt";
    
    readChar(fopen(in, "r"), fopen(out, "w"));
    getch();
    return 0;
}
Добавлено через 4 часа 38 минут
Не оставляйте в беде! Из всей программы только вот этот кусок сомнителен, посмтрите, пожалуйста
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
void readExp(FILE *in, FILE *out) {
    for (int i = 0; i < 100; i++) {
        expression[i] = 0;
    }
    int count = 0;
    int countStr = 0;
    
    for (int i = 0; i > -1; i++) {
        if (!feof(in)) {
            ch = getc(in);
            if (ch != '\n') {
            if (ch != ']') {
                expression[count] = ch;
                count++;
            } else {
                if (getc(in) == ']' && getc(in) == ']'){    
                    i = -2;
                } else {
                i=-2;
                    error();
                }
            }
            } else {
            countStr++;
            }
        } else {
        i=-2;
            error();
        }
    }
    
    float k = (mal_schet(1, (count - 1), expression) + 1);
    fprintf(out, "%f", k);
    for (int i = 0; i < countStr; i++) {
        putc('\n', out);
        }
 
}
 
void readChar(FILE *in, FILE *out) { 
    while (!feof(in)) {
        ch = getc(in);
        
            if (ch == '[') {
                if (getc(in) == '[' && getc(in) == '[') {
                    readExp(in, out);
                    } else {
                        error();
                        }
            } else {
                putc(ch, out);
            }
    }
    
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 05:24. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru