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

Подсчёт количества символов и замена - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Отсортировать и выдать на экран список http://www.cyberforum.ru/cpp-beginners/thread716564.html
После ввода с клавиатуры строками некоторых фамилий и рядом с ними возраста (год рождения) отсортировать и выдать на экран этот список, но отсортированными в порядке, обратном алфавитному, фамилиями
C++ Задача на двумерный массив (Удалить все столбцы по условию) в двумерном массиве , элементы которого все целые числа , произвести следующие действия . Удалить все столбцы , в которых все элементы положительны http://www.cyberforum.ru/cpp-beginners/thread716558.html
C++ Для каждой строки матрицы найти последний четный элемент и записать данные в новый массив
Дан массив размером n*n , элементы которого целые числа . Для каждой строки найти последний четный элемент и записать данные в новый массив
C++ Сделать отступы
Есть некоторый файл с четверостишиями, допустим text.txt Qwe Asd Zxc Rty Fgh Vbn Uio Jkl
C++ удаление чисел http://www.cyberforum.ru/cpp-beginners/thread716529.html
Составить функцию, которая, получив целое число, формирует новое число, удалив из него каждую четную цифру, начиная счет цифр с первой слева.
C++ Кол-во знаков препинания и букв в строке Требуется подсчитать кол-во букв и знаков препинания в строке, но программа упорно не хочет считать буквы, выдаёт кол-во равное нулю. В чём проблема? #include <conio.h> #include <iostream.h> #include <string.h> #include <stdlib.h> int main() { int i, size; char str; подробнее

Показать сообщение отдельно
-=ЮрА=-
Заблокирован
Автор FAQ
03.12.2012, 10:54     Подсчёт количества символов и замена
melanu, вот просто на Си (проект переделал под ввод с консоли, ввод через параметры за тобой)
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
#include <stdio.h>
#include <ctype.h>
#include <string.h>
#include <stdlib.h>//malloc
 
int poisk_AB(char *str);
char *zamena(char *str);
 
int main()
{
    char text[1024] = {0};//ГЃГіГґГґГҐГ° äëÿ ââîäèìîãî ГІГҐГЄГ±ГІГ*
    printf("Enter text : ");
    scanf("%[^\n]", text);//Ââîä ñòðîêè Г± ïðîáåëГ*ìè
    printf("Num chars among A-B : %d\n", poisk_AB(text));
    char * ptr = zamena(text);
    printf("String after replacing 0 : \n");
    if(ptr == NULL)
        printf("No replacing had been take\n");
    else
    {
        printf("%s\n", ptr);
        free((void *)ptr);
    }
    return 0;
}
 
int poisk_AB(char *str)
{
    int i      = 0;
    int FlagA  = 0;//Áóäåò îçГ*Г*Г·Г*ГІГј Г·ГІГ® Гў ñòðîêå Г*Г*éäåГ* ñèìâîë ГЂ
    int FlagB  = 0;//Áóäåò îçГ*Г*Г·Г*ГІГј Г·ГІГ® Гў ñòðîêå Г*Г*éäåГ* ñèìâîë Г‚
    int nCount = 0;
    if(str == NULL)
        printf("Empty string as param poisk_AB!\n");
    else
    {
        for(i = 0; i < strlen(str); i = i + 1)
        {
            if(toupper(str[i]) == 'A')
                FlagA = 1;
            if(toupper(str[i]) == 'B')
                FlagB = 1;
            if( FlagA && FlagB == 0)
                nCount = nCount + 1;
        }
        if(FlagA == 0)
            printf("String not contain symbol A!\n");
        else
        if(FlagB == 0)
            printf("String not contain symbol B!\n");
    }
    return nCount;
}
 
char *zamena(char *str)
{
    int i      = 0;
    int j      = 0;
    char * buf = 0;
    int nCount = 0;
    if(str == NULL)
        printf("Empty string as param poisk_AB!\n");
    else
    {
        //Ñ÷èòГ*ГҐГ¬ ñêîëüêî Г§Г*ìåГ* Г*Г*äî ïðîèçâåñòè
        for(i = 0; i < strlen(str); i = i + 1)
        {
            if(str[i] == '0')
                nCount = nCount + 1;
        }
        //Âûäåëÿì áîëüøóþ ГЇГ*ìÿòü (áîëüøóþ Г*Г* ÷èñëî Г§Г*ìåГ*)
        buf = (char *)malloc((strlen(str) + nCount + 1)*sizeof(char));
        if(buf == NULL)
            printf("Allocation memory error\n");
        else
        {
            for(i = (j = 0); i < strlen(str); i = i + 1)
            {
                if(str[i] == '0')
                {
                    buf[j]    = 'O';
                    buf[j + 1]= 'O';
                    j = j + 1;
                }
                else
                    buf[j] = str[i];
                j = j + 1;
            }
            buf[j] = 0;
        }
    }
    return buf;
}
Миниатюры
Подсчёт количества символов и замена  
 
Текущее время: 02:20. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru