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

Обработка символьного массива - C++

Восстановить пароль Регистрация
 
FKNL
0 / 0 / 0
Регистрация: 18.12.2013
Сообщений: 6
18.12.2013, 17:59     Обработка символьного массива #1
Итак, задание:
Без использования конструкции string написать программу ввода и вывода необходимого текста с клавиатуры. Ввод осуществляется до точки.
а) Вывести только маленькие латинские символы, пробелы и точку.
в) Вывести количество символов в введеном тексте и выведенном.
г) Вывести количество слов в выведенном тексте.
д) В выведенном тексте заменить на XXX каждое слово из 5 букв, имеющие в середине букву z.
Я не сделал только д. Помогите доделать.
Вот, что написал пока что:
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
#include <iostream>
#include <string>
using namespace std;
int main()
{
    setlocale(0,"rus");
    char a[666];
    int i=0;
    cout<<"Введите строку: \n";
    cin.getline(a,66);
    if (a[0]!='.')
        while(a[i]!='.') 
            i++; // Считываю каждый введенный символ, кроме точки.
    int l=0;
    cout << "Длина введенной строки (вместе с точкой):" <<endl;
    cout << i+1 <<endl;
    cout<<"***************************************"<<endl;
    for(int j=0;j<=i;j++)
    {
        if ((((int)a[j]>96)&((int)a[j]<123))||((int)a[j]==32)||((int)a[j]==46)) //Вывожу только от a до z, пробел и точку.
        {
            cout<<a[j];
            l++;  // Начисляю каждый символ, который выводим
        }
    }
cout<<endl;
cout << "Длина выведенной строки (вместе с точкой):" <<endl;
cout << l <<endl;
int k=0; 
for (int i=0; i<l; i++)
{
    if((char) a[i]!= 32)
    {
        do {
            i++;
            if ( (int) a[i]==32 || (int) a[i]==46)
            { 
                k++;
            }
        } while ( (int) a[i]!=32 && ( i<l) );
    }
}
cout << "Количество слов: " <<endl;
cout << k <<endl;
cout << "Заменим каждое слово из 5 букв и с третьтей буквой z на XXX"<<endl;
// ???
system("pause");
return 0;
}
Добавлено через 13 минут
Fix! В 32 строке в скобках int конечно для определения ASCII кода.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.12.2013, 17:59     Обработка символьного массива
Посмотрите здесь:

C++ Сортировка символьного массива
Заполнение массива значениями из символьного массива C++
C++ Размер символьного массива
из символьного массива в строковый, конкатенация C++
Инициализация символьного массива C++
C++ Обработка символьного массива
Удалить * из символьного массива C++
C++ Сортировка символьного массива

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Alex5
883 / 618 / 81
Регистрация: 12.04.2010
Сообщений: 1,552
18.12.2013, 18:44     Обработка символьного массива #2
Цитата Сообщение от FKNL Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
int k=0; 
for (int i=0; i<l; i++)
{
 if((char) a[i]!= 32)
 {
 do {
 i++;
 if ( (int) a[i]==32 || (int) a[i]==46)
 { 
 k++;
 }
 } while ( (int) a[i]!=32 && ( i<l) );
 }
}
cout << "Количество слов: " <<endl;
cout << k <<endl;
Вывести количество слов в выведенном тексте.
Нужны слова в выведенном тексте. Поэтому здесь должны быть не a[i], а те элементы которые выводятся.
д) В выведенном тексте заменить на XXX каждое слово из 5 букв, имеющие в середине букву z.
Может пригодиться функция strtok(). Также можно добавить подсчет длины слова
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
if((char) b[i]!= 32)  /* b[] - массив выводимых символов */
{
    int len = 0; // длина слова 
    do {
        ++len;
        i++;
        if ( (int) b[i]==32 || (int) b[i]==46)
        { 
            k++;
        }
    } while ( (int) b[i]!=32 && ( i<l) );
 
    // сюда добавим вывод на экран 
    //if( len == 5  && ( 3-й символ z ) ) { ... } else{ ... } 
}
FKNL
0 / 0 / 0
Регистрация: 18.12.2013
Сообщений: 6
19.12.2013, 01:40  [ТС]     Обработка символьного массива #3
Я дописал, всё работает. Выложу, может будет кому интересно потом.
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
#include <iostream>
#include <string>
using namespace std;
int main()
{
    setlocale(0,"rus");
    char a[666];
    char b[666];
    int i=0;
    int l=0;
    cout<<"Введите строку: \n";
    cin.getline(a,66);
    if (a[0]!='.')
        while(a[i]!='.') 
            i++;
    cout << "Длина введенной строки (вместе с точкой):" <<endl;
    cout << i+1 <<endl;
    cout <<"***************************************"<<endl;
    cout <<"Выведены только маленькие латинские символы, пробелы и точка"<<endl; 
    for(int j=0;j<=i;j++)
    {
        if ((((int)a[j]>96)&((int)a[j]<123))||((int)a[j]==32)||((int)a[j]==46)) // ascii коды: 96-"a", 123-"z", 32-" ", 46- ".'
        {
            b[l]=a[j];
            cout<<a[j];
            l++;  
        }
    }
cout<<endl;
cout << "Длина выведенной строки (вместе с точкой):" <<endl;
cout << l <<endl;
 
cout << "Заменим каждое слово из 5 букв и с третьтей буквой z на XXX"<<endl;
int k=0; 
for (int i=0; i<l; i++)
{
    if((int) b[i]!= 32)
    {
        int len=0; // Длина слова;
        do {
            ++len; 
            i++;  
            if ( (int) b[i]==32 || (int) b[i]==46)
            { 
                k++;
            }
        } while ( (int) b[i]!=32 && (int) b[i]!=46);
        if (len==5 && (int) b[i-3]==122)
        {   
            b[i-1]=8;
            b[i-3]='X';
            b[i-4]='X';
            b[i-5]='X';
        }
    }
} 
for (int i=0; i<l; i++)
{
    cout << b[i];
}
cout<<endl;
cout << "Количество слов: " <<endl;
cout << k <<endl;
system("pause");
return 0;
}
Yandex
Объявления
19.12.2013, 01:40     Обработка символьного массива
Ответ Создать тему
Опции темы

Текущее время: 14:34. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru