Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 26.03.2014
Сообщений: 16
1

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

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

Author24 — интернет-сервис помощи студентам
почему-то при любом количестве строк,которое я задаю,он позволяет написать только одну,а потом переходит к следующему пункту и вообще вылетает,хотя скомпелирован корректно
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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
24.05.2014, 23:37
Ответы с готовыми решениями:

Циферблат аналоговых часов, есть код но он работает не совсем корректно
Здравствуйте, собственно написал код для вывода циферблата часов, просто по нажатию на кнопку. Код...

Не совсем корректно работает Like
Добрый день! Подскажите пожалуйста в чем загвоздка? Имеем две формы. Выбор и Заказы. Первичная -...

не совсем корректно работает
скрипт повесил в onload, но после загрузки страницы в браузере firefox остается значок загрузки...

Не совсем корректно работает программа
Нужно написать программу которая считает сумму 2-х предыдущих чисел (кол-во чисел пользователь...

6
76 / 71 / 55
Регистрация: 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
0 / 0 / 0
Регистрация: 26.03.2014
Сообщений: 16
25.05.2014, 00:05  [ТС] 3
ой,точно,спасибо)

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

Добавлено через 1 минуту
Хедин,нам сказано делать через malloc и тп,так то я бы через int делала...
0
76 / 71 / 55
Регистрация: 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
0 / 0 / 0
Регистрация: 26.03.2014
Сообщений: 16
25.05.2014, 00:10  [ТС] 5
он все равно выводит после одной строки следующую команду
0
76 / 71 / 55
Регистрация: 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
0 / 0 / 0
Регистрация: 26.03.2014
Сообщений: 16
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
01.06.2014, 14:39
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
01.06.2014, 14:39
Помогаю со студенческими работами здесь

Суммирование по условию работает не совсем корректно
Добрый день! Написал макрос для суммирования по условию: Sub страхование() Dim insur As...

Программа не завершается и не совсем корректно работает
Итак, есть следующая программа отправляющая запрос и принимающая ответ. .h file #ifndef...

Парсер на php не совсем корректно работает
Написал парсер на php. но столкнулся с некоторыми сложностями. Есть сайт с которого я подтягивая...

Реестр, вроде и работает но не совсем корректно
Procedure FirstRun(val:boolean); begin UserData:=tregistry.Create; try if not...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru