Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
DarkTerm
0 / 0 / 0
Регистрация: 29.05.2010
Сообщений: 1
1

Строка. Замена символа. Самое длинное слово

01.06.2010, 16:04. Просмотров 553. Ответов 0
Метки нет (Все метки)

Приветствую.
Нужна помощь в доработке или переделки программы.
Дана строка символов и некоторый символ sym. Сформируйте новую строку, вставив после каждого вхождения символа sym запятую. Определите самое длинное слово в строке.

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
// fuckthenall.cpp : Defines the entry point for the console application.
//
 
#include "stdafx.h"
#include <iostream>
#include <conio.h>
#include <string.h>
using namespace std;
 
/****************************************************************************************
Дана строка символов и некоторый символ sym. 
Сформируйте новую строку, вставив после каждого вхождения символа sym запятую. 
Определите самое длинное слово в строке.
****************************************************************************************/
 
 
int main(void)
{
    int i,j,a;
    bool x();
    char str[]="hhhlhhh hhlhh hlh";
    char sym[]="l";
    char sym2[]="h";
    char s[]=", ";
    char p1[666];
    char* newstr=new char[80];
 
    a=0;
    char* pbegin = str;
    char* psubstr = str;
    char* pfinal = str;
 
    int len,dez;
    while ( (psubstr = strpbrk (psubstr,sym)) !=NULL)
    {
        cout << "substring " << psubstr << endl;
        psubstr++;
        len =  psubstr - pbegin;
        pfinal = strpbrk (psubstr,sym2);
      
        strncpy(newstr, pbegin, len);
        newstr[len] = 0;
        strcat(newstr,s);
        strcpy(p1,newstr);
 
        dez=4;
        cout << "pfinal " << pfinal << endl;
        strncat(p1, pfinal,dez);
        cout << "newstr " << newstr << endl;
        cout << "p1 " << p1 << endl;
 
 
 
            
    };
 
/*
    int len = (int)strlen(str);
    for (i=0; i<len; i++)
    {   
        if (str[i]==sym[1])
        { a=i;
 
        strncpy(newstr,str[],a);
        strcat(newstr,s);
        }
        
    }
    
    for (i=0; i<(int)strlen(newstr);i++)
    cout << "" << newstr[i]; */
 
 
 
    delete [] newstr;
    return 0;
}
Немогу довести до конца так, чтобы получилось hhhl, hhh hhl, hh hl, h
Вообще все как то мудрено получилось
Можно проще, но смысл работы еще и в том чтобы использовать всякие strcmp, strcpy
Еще можно попробывать через strtok, но я так и не понял как он работает!
Заранее благодарю за помощь!
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.06.2010, 16:04
Ответы с готовыми решениями:

Строки. В заданном тексте найти самое длинное слово и самое длинное предложение.
Задача: В заданном тексте найти самое длинное слово и самое длинное...

Найти в тексте самое длинное слово и самое длинное предложение
вписать текст с клавиатуры и найти в этом тексте самое длинное слово и самое...

Строка: На основе исходной сформировать новую строку, в которой самое длинное слово поставить в начало.
Дана строка. На основе исходной сформировать новую строку, в которой самое...

Поменять местами самое длинное слово и самое короткое слово в тексте
Пусть есть двумерный массив, заполненный символами. Рассматривать его как...

В заданном предложении найти самое короткое и самое длинное слово
Строка вводится с клавиатуры. Нужно выполнить задание, не применяя функций...

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
01.06.2010, 16:04

Найдите самое длинное, и самое короткое слово в заданном предложении
Найдите самое длинное и самое короткое слово в заданном предложении.

Поменять местами в предложении самое длинное и самое короткое слово
Сам код, но тут 12 ошибок выдает в логе: #include &quot;stdafx.h&quot; #include...

В заданной строке определить самое длинное и самое короткое слово
Ввести несколько строк,каждая из которых содержит некоторое количество слов.В...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

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