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

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

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

Код работает не совсем корректно со строками - C++

24.05.2014, 23:37. Просмотров 298. Ответов 6
Метки нет (Все метки)

почему-то при любом количестве строк,которое я задаю,он позволяет написать только одну,а потом переходит к следующему пункту и вообще вылетает,хотя скомпелирован корректно
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
#include <stdio.h>
#include <conio.h>
#include <malloc.h>
#include <iostream>
#include <string.h>
int main()
{
    int a, i, j, k, l, min, kol_str, kol_razd, kol_slov;
    char *new_word, **text, **new_text, b, *razd;
 
    printf("vvedi kolichestve strok: ");
    scanf("%d", &kol_str);
 
    text=(char**)malloc(kol_str*sizeof(char));
    for(i=0; i<kol_str; i++)
 
    text[i]=(char*)malloc(sizeof(char));
    printf("vvedi tekst: \n");
    for(i=0, b=' '; b!='\n' || i<kol_str; i++)
    {
        b=getchar();
        text[i]=(char*)realloc(text[i], (j+1)*sizeof(char));
        if(b!='\n')
        {
            text[i][j]=b;
            j++;
        }
        else
            text[i][j]='\0';
    }
 
    razd=(char*)malloc(sizeof(char));
    new_text=(char**)malloc(kol_str*sizeof(char));
    printf("vvedi razdeliteli: \n");
    i=0;
    b=' ';
    while(b!='\n')
    {
        b=getchar();
        razd=(char*)realloc(razd, (i+1)*sizeof(char));
        if(b!='\n')
        {
            razd[i]=b;
            i++;
        }
        else
            razd[i]='\0';
    }
    kol_razd=strlen(razd);
    do
    {
        do
        {
            j=0;
            while(j<kol_razd)
            {
                if(text[i][j]!=razd[k])
                    k++;
                else
                    break;
            }
            if(j==kol_razd)
            {
                l++;
                if(text[i][j+1]=='\0')
                    kol_slov++;
            }
            else
            {
                if(l!=0)
                    kol_slov++;
                if(min>l)
                    min=l;
                l=0;
            }
            j++;
        }
        while(text[i][j]!='\0');
        a=kol_slov%2;
        if(a!=0)
        {
            a=strlen(text[i]);
            new_text[l]=(char*)malloc(a*sizeof(char));
            strcpy(new_text[l], text[i]);
        }
        i++;
    }
    while(i<kol_str);
    printf("BBeguTe cJIoBo");
    new_word=(char*)malloc(sizeof(char));
    i=0;
    b=' ';
    while(b!='\n')
    {
        b=getchar();
        new_word=(char*)realloc(new_word, (i+1)*sizeof(char));
        if(b!='\n')
        {
            new_word[i]=b;
            i++;
        }
        else
            new_word[i]='\0';
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.05.2014, 23:37
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Код работает не совсем корректно со строками (C++):

Алгоритм шифрования RC4 не совсем корректно работает - C++
Всем привет! Знаю что тема избитая, но всё таки хочется понять проблему и решить. Алгоритм разобрал и написал. Спасибо википедии. ...

Работа со строками. Програма работает, но не совсем так. - C++
помогите пожалуйста мне задали увеличить строку символов за счет вставки между словами пропусков я сделал программу но пропусков она не...

Не совсем понятно как работает такой код - C++
Есть консольное приложение, которое при работе выводит данные. Непонятно как работает такой код: for (;;) { char option; ...

не совсем понимаю код *указатели - C++
изучаю указатели, столкнулся с кодом не совсем могу понять что происходит в функции *g_s, особенно это условие *p2 &amp;&amp; *p2 == *p ...

setlocale не совсем работает - C++
есть код: #include &lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;clocale&gt; using namespace std; int main() { setlocale...

Пытаюсь переписать код с циклом for, в код с циклом while, но не совсем получается - C++
Возникло пару вопросов: #include &lt;iostream&gt; using namespace std; int main () { for (int i = 0; i&lt;=10; i++) cout &lt;&lt;...

6
Хедин
73 / 68 / 36
Регистрация: 17.05.2014
Сообщений: 301
24.05.2014, 23:45 #2
Anastezia, text=(char**)malloc(kol_str*sizeof(char)); у вас тут звездочки не хватает, вы ведь делаете массив указателей на char
C++
1
text=(char**)malloc(kol_str*sizeof(char*));
и почему вы создаете массив указателей на символы?
C++
1
text[i]=(char*)malloc(sizeof(char));
не проще было сразу сделать
C++
1
text = (char*)malloc(sizeof(char)*kol_str);
да и по С++ лучше делать
C++
1
2
text = new char*[kol_str];
for (int i = 0; i < kol_str; i++) text[i] = new char[100];
0
Anastezia
0 / 0 / 0
Регистрация: 26.03.2014
Сообщений: 14
25.05.2014, 00:05  [ТС] #3
ой,точно,спасибо)

Добавлено через 15 минут
это важное замечание,я в двух местах исправила,но все равно не работает

Добавлено через 1 минуту
Хедин,нам сказано делать через malloc и тп,так то я бы через int делала...
0
Хедин
73 / 68 / 36
Регистрация: 17.05.2014
Сообщений: 301
25.05.2014, 00:07 #4
Anastezia, ну тогда если вы хотите в text хранить массив строк, то выделяйте память не на один символ, а на строку, например на 100 символов...
C
1
2
3
text=(char**)malloc(kol_str*sizeof(char*));
for (i = 0; i < kol_str; i++)
    text[i]=(char*)malloc(sizeof(char)*100);
0
Anastezia
0 / 0 / 0
Регистрация: 26.03.2014
Сообщений: 14
25.05.2014, 00:10  [ТС] #5
он все равно выводит после одной строки следующую команду
0
Хедин
73 / 68 / 36
Регистрация: 17.05.2014
Сообщений: 301
25.05.2014, 00:24 #6
Anastezia, вот такая программа работает корректно
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <stdio.h>
#include <stdlib.h>
 
int main(int argc, char **argv)
{
    int i, kol_str = 5; char **text;
    text=(char**)malloc(kol_str*sizeof(char*));
    for (i = 0; i < kol_str; i++)
        text[i]=(char*)malloc(sizeof(char)*100);
    for (i = 0; i < kol_str; i++)
    {
        printf("Введите строку %i:", i+1); fgets(text[i], 100, stdin);
    }
    for (i = 0; i < kol_str; i++)
    {
        printf("Строка  %i: %s", i+1, text[i]);
    }   
    for (i = 0; i < kol_str; i++) free(text[i]);
    free(text);
    return 0;
}
0
Anastezia
0 / 0 / 0
Регистрация: 26.03.2014
Сообщений: 14
01.06.2014, 14:39  [ТС] #7
В общем с вводом все ок,теперь не хочет работать killer
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
#include<iostream>
#include<conio.h>
#include<malloc.h>
using namespace std;
 
 
int len(char*);
bool isPun(char,char*);
int godOfF(char*,char*,int,int);
char* killer(char*,char*,char*);
char* clone(char*);
char* read();
int sword(char*,char*,int);
 
int main()
{
    int j,ks,k;
    char *razd,*slovo;
    char** text1;
    char** text2;
    printf("Vvedite kol_vo strok: " );
    cout<<"\n";
    cin>>k;
    text1=(char**)malloc(k*sizeof(char*));////var arrays
    text2=(char**)malloc(sizeof(char*));
    razd=(char*)malloc(sizeof(char));
    slovo=(char*)malloc(sizeof(char));
    cout<<"Davay epta"<<"\n";
    razd=read();
    cout<<"Text\n";
    j=0;
    ks=0;
    while(j<k){
               text1[j]=read();
               j++;
     }
    for (j=0;j<k;j++){
           if (godOfF(text1[j],razd,3,0)%2!=0){
                    ks++;
                    text2=(char**)realloc(text2,ks*sizeof(char*));
                    text2[ks-1]=clone(text1[j]); 
           }   
     }/////////end
    cout<<"slovo"<<"\n";
    slovo=read();
    for (j=0;j<k;j++) cout<<text1[j]<<"\n";
    cout<<"Reformed text:\n";
    for(j=0;j<ks;j++){
        text2[j]=killer(text2[j],slovo,razd);
        cout<<text2[j]<<"\n";
    }
 
    getch();
       for (j=0;j<k;j++) free(text1[j]);
       free(text1);
       for (j=0;j<ks;j++) free(text2[j]);
       free(text2);
       free(razd); 
    return 0;
}
char* read(){
    char *str=(char*)malloc(sizeof(char));
    int i=0;
    while((str[i]=_getche())!='\r'){                                          
           i++;
           str=(char*)realloc(str,(i+1)*sizeof(char));
    }     
    str[i]='\0'; 
    cout<<"\n";
    return str;
}
char *killer(char* str,char* word,char* pun){
    int min=godOfF(str,pun,1,0);
    int ind=0;
    int lw=len(word)-1;
    int i=0;
    int j=0;
    do{
        ind=godOfF(str,pun,2,ind);
        if(lw<min){
            for(j=0;j<(min-lw);j++){
                i=ind+min;
                while (str[i]!='\0'){
                    str[i]=str[i+1];
                    i++;
                }   
            }
            str=(char*)realloc(str,len(str)*sizeof(char));
        }
        if(lw>min){
            str=(char*)realloc(str,(len(str)+lw-min)*sizeof(char));
            for(j=0;j<(lw-min);j++){
                i=len(str);
                
                while (i>(ind+min)){
                    str[i+1]=str[i];
                    i--;
                }   
            }
        }
        lw=0;
        i=ind;
        while(word[lw]!='\0'){
            str[i]=word[lw];
            i++;
            lw++;
        }
      cout<<ind<<"\n";
    }while(godOfF(str,pun,1,ind)==min);
    return str;
} 
int godOfF(char* str,char* pun,int w,int index){
     int i,lenW,indM,k,min;
     i=index;
     if (index!=0) while((!isPun(str[i],pun)) && (str[i]!='\0')) i++;
     min=0;
     k=0;
     indM=len(str)-1;
         while(str[i] != '\0'){         
            while(isPun(str[i],pun)) i++;          
            if (str[i]=='\0') break;
            k++;
            lenW=0;
            while(!isPun(str[i],pun)&& (str[i]!='\0')){
               i++;
               lenW++;
               
            }
            if ((lenW<min)&(min>0)){ 
               min=lenW;
               indM=i-min;
               }                                         
     }
     switch (w){
            case 1: return min;    
            case 2: return indM; 
            case 3: return k; 
     } return 0 ;   
}
int len(char* pun){
     int k=0;     
     while(pun[k] != '\0') k++;
     k++; 
     return k;
}
bool isPun(char c,char* pun){
     int i;
     bool j;
     j=false;
      for (i=0;i<(len(pun)-1);i++) if (c==pun[i]) j=true;
      return j;
}
char* clone(char* is){
     int i; 
     int a=len(is);
     char* str=(char*)malloc(a*sizeof(char));
     for (i=0;i<a;i++) str[i]=is[i];
     return str;
}
int sword(char* str,char* pun,int ind){
    int i=ind;
    if ((ind==0)&&(!isPun(str[i],pun))) return 0;
 
    while((!isPun(str[i],pun)) && (str[i]!='\0')) i++;
    while((isPun(str[i],pun))&&(str[i]!='\0')) i++;
    if (str[i]=='\0') return -1;
    return i;
}
Добавлено через 3 часа 33 минуты
задание такое:составить из исходного текста новый,в который войдут строки с нечетным кол-вом символов,в этих строках слова минимальной длины заменить на слово пользователя
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
01.06.2014, 14:39
Привет! Вот еще темы с ответами:

Программа работает не совсем правильно - C++
Вообщем вот условие. Создать класс, содержащий сведения о количестве изделий, собранный сборщиками цеха за неделю. Класс должен содержать...

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

Не совсем правильно работает простенькая программа - C++
Получить таблицу температур по Цельсию от 0 до 100 градусов и их эквивалентов по шкале Фаренгейта, используя для перевод формулу tf =...

Не корректно работает - C++
I need help. Не могу понять почему мой код при считывание с одного файла и записи в другой пропускает первый символ. Буду очень благодарен...


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

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

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