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

Не могу понять ошибку

09.07.2014, 10:20. Показов 880. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
По задумке надо удалить два идущих подряд одинаковых слова. Задумка не выходит, выдаёт бурду...
HELP ME!(
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
#include "stdafx.h"
#include <iostream>
#include <fstream>
#include <iomanip>
#include <stdio.h>
#include <Windows.h>
#include <string>
 
using namespace std;
int _tmain (int argc, _TCHAR* argv[])
{   
    setlocale (LC_ALL, "RUS");
    FILE *fp = fopen("Текст.txt","r");
    if ( NULL == fp )
    {
    printf("Не удалось открыть файл.");
    return 0;
    }
    char s[1024]="";
    char *b[1024]={0};
    char *Ptr=NULL;
    while (!feof(fp))
    {
        fgets(s,1024,fp);}
    
    const char separator[]=" .,!?";
    int t=0;
    b[t]=strtok(s,separator); //Исходная строка будет изменена
    
    while (Ptr)
    {
       b[t]=Ptr;
       Ptr=strtok(0,separator); //указываем на новый токен
      
       if(b[t]=b[t+1])
       {
       b[t+1]='\0';
       } 
t++;
       
    }
 
    
    
    printf("%s",b);
    system("pause");
    fclose(fp);
    }
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.07.2014, 10:20
Ответы с готовыми решениями:

Не могу понять ошибку
Всем привет. Делаю задание из универа. В принципе все работает с использованием дружественного класса, но хочется обойтись без...

Не могу понять ошибку
#include &lt;iostream.h&gt; #include &lt;math.h&gt; int main () { double x,a,d,h,t,e,g,b,c,z,y,s,rezylt; не могу понять чем программе sqrt...

Не могу понять ошибку
Вот такая программа, реализующая односвязный список: #include &lt;iostream&gt; #include &lt;clocale&gt; #include &quot;listStruct.h&quot; ...

8
2688 / 2260 / 244
Регистрация: 03.07.2012
Сообщений: 8,231
Записей в блоге: 1
09.07.2014, 10:21
Учись отладчиком пользоваться, однако
0
Эксперт С++
1675 / 1047 / 174
Регистрация: 27.09.2009
Сообщений: 1,945
09.07.2014, 10:23
Вот почему печатается бред:
Цитата Сообщение от Glebordan Посмотреть сообщение
C++
1
2
3
char *b[1024]={};
// ...
printf("%s",b);
0
0 / 0 / 0
Регистрация: 07.04.2014
Сообщений: 37
09.07.2014, 10:35  [ТС]
Ну не знаю, проблемы это не решило...может стоит попробовать добавить две переменные типа string и затаскивать в эти переменные первое слово и идущее за ним следом слово, сравнивать их и потом опять возвращать в массив?
0
Эксперт PHP
 Аватар для Kerry_Jr
3106 / 2591 / 1219
Регистрация: 14.05.2014
Сообщений: 7,236
Записей в блоге: 1
09.07.2014, 11:05
Цитата Сообщение от Glebordan Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
10
while (Ptr)
{
    b[t]=Ptr;
    Ptr=strtok(0,separator); //указываем на новый токен
    if(b[t]=b[t+1])
    {
        b[t+1]='\0';
    } 
    t++;
}
А у Вас этот цикл выполняется вообще?

Добавлено через 8 минут
Если я не ошибаюсь, то указателю Ptr изначально присвоен NULL, и до этого цикла его значение нигде не изменяется.
0
0 / 0 / 0
Регистрация: 07.04.2014
Сообщений: 37
09.07.2014, 11:09  [ТС]
Да, верно цикл не выполнялся, это исправил:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
 while (!feof(fp))
    {
        fgets(s,1024,fp);}
    
    const char separator[]=" .,!?";
    int t=0;
    Ptr=strtok(s,separator); //Исходная строка будет изменена
    
    while (Ptr)
    {
       b[t]=Ptr;
       Ptr=strtok(0,separator); //указываем на новый токен
      
       if(b[t]=b[t+1])
       {
       b[t+1]='\0';
       } 
      t++;
       
    }
но теперь тупо удаляется весь текст....
0
1130 / 789 / 232
Регистрация: 12.04.2010
Сообщений: 2,012
09.07.2014, 12:55
Цитата Сообщение от Glebordan Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
10
while (Ptr)
 {
 b[t]=Ptr;
 Ptr=strtok(0,separator); //указываем на новый токен
if(b[t]=b[t+1])
 {
 b[t+1]='\0';
 } 
 t++;
}
Попробуйте разобраться с такими вопросами.
Сравнение строк. Какие строки нужно сравнить? Как выполнить сравнение строк char[]?
C++
1
2
Ptr=strtok(0,separator); //указываем на новый токен 
  /* Что делать, если функция strtok() вернёт нулевой указатель? */
1
Модератор
Эксперт С++
 Аватар для zss
13778 / 10971 / 6491
Регистрация: 18.12.2011
Сообщений: 29,258
09.07.2014, 13:07
Цитата Сообщение от Glebordan Посмотреть сообщение
if(b[t]=b[t+1])
1. для сравнения используется оператор == , а не =
2. строки сравнивать надо через strcmp
C++
1
if(strcmp(b[t],b[t+1])==0 )
1
0 / 0 / 0
Регистрация: 07.04.2014
Сообщений: 37
09.07.2014, 13:20  [ТС]
Спасибо большое за ваши советы
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.07.2014, 13:20
Помогаю со студенческими работами здесь

не могу понять ошибку
Народ, здарова, сижу над классами, конкретно наследование классов! Компилятор выдает ошибку: Unit1.cpp(143): E2285 Could not find a...

не могу понять ошибку
#include &lt;iostream&gt; using namespace std; int main(); { double a=0, b-0, c=0; cout &lt;&lt;&quot;a&quot;; cin &gt;&gt; a; cout &quot;b&quot;...

Не могу понять ошибку
#include&lt;iostream.h&gt; #include&lt;math.h&gt; #include&lt;conio.h&gt; #include&lt;stdio.h&gt; int main() { double x=3.741, y=-0.825,z=0.160, A,...

Не могу понять ошибку
Пытаюсь решить вот эту задачу https://www.cyberforum.ru/cpp-beginners/thread356063.html Есть решения на бэйсике вот...

Не могу понять ошибку компиляции
Вообщем я только учусь работать в С++, и вот узнал про цикл While, решил создать простую программу как самоучителе и посмотреть как она...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача №1: при указании работ (справочник РаботыПоРемонтуСпецтехники),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru