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

strcat - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Защита от дурака (пустое значение в названии) http://www.cyberforum.ru/cpp-beginners/thread1030521.html
Доброго вечера) Я пытаюсь сделать защиту от дурака, если конкретно - проверку при на ввод названия пустого значение, т.е. пробела или энтера. Только вот с энтером проблема. Объясните, если не сложно в чем моя ошибка) do{flag=0; cout<<"Введите название книги: "; gets (b); if((b==' ') flag=1; for(i=0;i<strlen(b); i++) {if(b=='\n') flag=1; }
C++ фейл при чтении из файла Вот абсолютно работоспособный код, где чтение и запись выполняются непосредственно в main. #include <iostream> #include <fstream> #include <string> using namespace std; class Goods{ protected: string Name; public: http://www.cyberforum.ru/cpp-beginners/thread1030519.html
Составить таблицу ступенчатой функции C++
Дошел до ступенчатой функции, не могу понять как делать,помогите y=(tgx*sqrt(p^2-x^2))/(ln(p+2)) , 0<=x<1;dx=0.2; y=(lg(x+1)*arctg(p))/(sqrt(x^2+4x-7))+(2p/x), 1<=x<2;dx=0.5;0<=p<=5;dp=0.25
C++ Сумма элементов правее побочной диагонали, где строка начинается с отрицательного элемента
Есть квадратная матрица. Нужно посчитать сумма элементов правее побочной диагонали, где строка начинается с отрицательного элемента sum = 0; cout<<"Вычисление суммы элементов, расположенных правее побочной диагонали в строках, начинающихся с отрицательного элемента"<<endl; for(i = 0; i < s; i++) for(j = 0; j < s; j++){ //if(mas < 0) if((s - j - 1) < i){ sum = sum + mas;...
C++ Программа с затруднительной концовкой http://www.cyberforum.ru/cpp-beginners/thread1030471.html
Привет всем. У меня Программа нуждающаяся в помощи. Нужна помощь с задачей. Вот условие: Есть информационный массив f, в котором данные о книгах. (фамилия автора, название и год печати). б) определить есть книга с названием «Информатика». Если есть, то выдать фамилия автора и год печати. Если таких книг несколько, то выдать все данные по этим книгам. У меня не получается реализовать эту часть...
C++ вложенность прямоугольников bool Intersects(Rect Obj1, Rect Obj2) { int x1 = Obj1.ItsLeftUpperGetX(); int y1 = Obj1.ItsLeftUpperGetY(); int x2 = Obj1.ItsRightLowerGetX(); int y2 = Obj1.ItsRightLowerGetY(); int a1 = Obj2.ItsLeftUpperGetX(); подробнее

Показать сообщение отдельно
Pavel_B
0 / 0 / 0
Регистрация: 06.12.2013
Сообщений: 6
06.12.2013, 02:28     strcat
Доброго времени суток и спасибо, что зашли посмотреть мою проблему.
Дело в том, что я делаю такую вещь: с блокнота считываю построчно и с помощью написанной функции удаляю среднее слово. С этим проблем нет. Но когда я после того обработал строку, удалил из неё слово, я хочу записать её в новый динамический массив, в котором будет храниться весь текст, который я после прохождения файла опять же вкину в тот же блокнот. Весь код:
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
#include <stdio.h>
#include <string.h>
#include <conio.h>
 
void del_word(char *read_string, char *&new_string);
 
void main(void)
{
    FILE *file;
    char read_string[100]; //строка, которая будет прочитана
    char *new_string; //строка, которая будет записана
    
    char *new_text = new char [1];
    
    
    int n; //кол-во слов в строке
    file = fopen("LR7_text.txt", "r+"); //открываем файл для чтения и записи
    
    if(file) //проверяем на наличие файла
    {
        while(!feof(file)) //пока данные в файле не закончатся - выполняем над ними действия
        {
            fgets(read_string, sizeof(read_string), file); //читаем построчно
            del_word(read_string, new_string); //удаляем слово
            printf("\nFinish:%s\n+++++++++++++++++++++++++++++++", new_string ); //проверка на возврат нужной строки
            strcat(new_text, new_string); //записываем вновь обработанной строки в общий текст, который потом запишем
        }
    
    }
    else
    printf("File is not avaleble!"); //если файл не найден
    
    //fputs("\nNEW TEXT\n",file); //что бы было видно, где обработанный текст
    //fputs(new_text, file); //записываем новый текст   
    fclose(file); //закрываем файл
    printf("\nGotovo!!!\n%s", new_text);
    getch();
}
 
void del_word(char *read_string, char *&new_string) //передаем прочитанную строку, а результат работы функции изменяем в new_string
{
unsigned int n = 0; //кол-во слов
int will_del; //после какого пробела удалять слово
 
for (int i=0;i<strlen(read_string)+1;i++)
if ((read_string[i]==' ') && (read_string[i+1]!=' ')) //считаем кол-во слов
    n++;
 
if (read_string[0]!=' ') //если 1-ый символ пробел, то слов как и пробелов
    n=n+1;
printf("\nStroka:%s", read_string); 
 
 
 
if(read_string[0] == ' ')
    will_del = n/2+1;
else
    will_del = n/2;
 
new_string = new char[strlen(read_string)+1]; //новая строка для готового текста
 
n = 0;
for(int i = 0, a = 0; i<strlen(read_string)+1; i++,a++)
{
    
    if ((read_string[i]==' ') && (read_string[i+1]!=' '))
    {   
        
        n++;
        if(n == will_del)
        {
            new_string[a]=read_string[i];
            while(read_string[++i]!=' ');
            n=0;
        }
 
        else
            new_string[a]=read_string[i];           
    }
    
    else
    new_string[a]=read_string[i];
}
 
//printf("\n**********************************\nStroka:%s", new_string);
}
Если просто же написать char *new_text; и к нему присоединять обработанную строку(new_string), то выдает ошибку.
Если делать так:
char *new_text = new char [10];
new_text = "NEW TEXT\n";
тоже выдает ошибку. Нашел немного глупый способ (и даже не знаю, почему именно он работает=) ), он и написан в коде.
Надеюсь на вашу помощь.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 16:09. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru