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

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

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

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

24.05.2014, 23:37. Просмотров 285. Ответов 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';
    }
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.05.2014, 23:37     Код работает не совсем корректно со строками
Посмотрите здесь:
C++ Алгоритм шифрования RC4 не совсем корректно работает
C++ Работа со строками. Програма работает, но не совсем так.
Не совсем понятно как работает такой код C++
C++ не совсем понимаю код *указатели
C++ setlocale не совсем работает
Пытаюсь переписать код с циклом for, в код с циклом while, но не совсем получается C++
C++ Программа работает не совсем правильно
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Хедин
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];
Anastezia
0 / 0 / 0
Регистрация: 26.03.2014
Сообщений: 14
25.05.2014, 00:05  [ТС]     Код работает не совсем корректно со строками #3
ой,точно,спасибо)

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

Добавлено через 1 минуту
Хедин,нам сказано делать через malloc и тп,так то я бы через int делала...
Хедин
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);
Anastezia
0 / 0 / 0
Регистрация: 26.03.2014
Сообщений: 14
25.05.2014, 00:10  [ТС]     Код работает не совсем корректно со строками #5
он все равно выводит после одной строки следующую команду
Хедин
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;
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
01.06.2014, 14:39     Код работает не совсем корректно со строками
Еще ссылки по теме:
Программа работает, не не совсем правильно... C++
C++ Не совсем правильно работает простенькая программа
Работает не корректно C++
C++ Не корректно работает
C++ Не могу корректно прочитать код

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

Или воспользуйтесь поиском по форуму:
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 минуты
задание такое:составить из исходного текста новый,в который войдут строки с нечетным кол-вом символов,в этих строках слова минимальной длины заменить на слово пользователя
Yandex
Объявления
01.06.2014, 14:39     Код работает не совсем корректно со строками
Ответ Создать тему
Опции темы

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