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

Strings - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Обработка строк. http://www.cyberforum.ru/cpp-beginners/thread126063.html
Определить, сколько раз в строке встречается последовательность символов «ВЕС».
C++ RSA-степень-переполнение Хай. Проблема: нужно возводить в степень большие числа (это для шифрования методом RSA). НО: если результат меньше 19 знаков, то все в порядке. А если больше - не считает, т.к. выходит за диапазон __int64 (Например, 29^13). Что делать с этим переполнением? http://www.cyberforum.ru/cpp-beginners/thread126034.html
перевод из строк в числа C++
помогите с корректированием задачи: дан текст, содержащий целые числа, составить программу, которая выводит на экран минимальное из чисел. тут идея с поиском в строке целых чисел и закидыванием их в массив, идея оказалась полной фигней. сделал потом решение без массива, но файл с кодом благополучно потерян. за индусский код просьба не кидать помидоры >_< #include "iostream" #include...
сортировка для Циклического спика C++
что здесь не правильно //----------------------- Sort_THE_LIST---------------------- void sort_the_list() {student *temp; student *prew=Head; student pNext=temp->Next; for(int i=0;i<counter;i++) { for(int j=0;j<counter;j++)
C++ Найти сумму бесконечного ряда http://www.cyberforum.ru/cpp-beginners/thread126005.html
нужна помощь , прогу написал но есть ошибки, посмотрите со стороны че исправить ? :) #include <iostream> #include <math.h> #include <clocale> #include <iomanip> using namespace std; int main() {
C++ рекурсия Помогите пожалуйста сделать рекурсию Даны n и m, найти X и Y, при X1=Y=1 X=X+Y/i^2 Y=Y=X/i^2 подробнее

Показать сообщение отдельно
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9372 / 5422 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
06.05.2010, 16:49     Strings
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
/*
*   Для произвольного текста, содержащего не более 10 строк, в каждой строке не более 80 символов,
*   сформировать массив, элементы которого равны длинам слов. Вывести на экран исходный текст
*   и сформированный массив.
*/
 
#define ROWS_MAX 10
#define ROW_LEN 81 /* + '\0' */
#define SP_CHARS " ,.!?\t\n"
 
int main(void){
    char *rows[ROWS_MAX], buf[ROW_LEN], *p, *row;
    int *counters[ROWS_MAX], cntRows, i, j;
 
    printf("Enter some strings of the text ended by empty one, but it is no more %d.\n", ROWS_MAX);
    for ( cntRows = 0; cntRows < ROWS_MAX; ++cntRows ){
        if ( ! fgets(buf, ROW_LEN, stdin) ){
            perror("fgets");
            exit(1);
        }
        if ( p = strrchr(buf, '\n') )
            *p = '\0';
        if ( !*buf )
            break;
        if ( ( rows[cntRows] = strdup(buf) ) == NULL ){
            perror("strdup");
            exit(1);
        }
    }
 
    if ( ! cntRows ){
        fprintf(stderr, "No strings arrived!\n");
        exit(1);
    }
 
    for ( i = 0; i < cntRows; ++i ){
        if ( ( counters[i] = calloc(1, sizeof(int)) ) == NULL ){
            perror("calloc");
            exit(1);
        }
        if ( ( row = strdup(rows[i]) ) == NULL ){
            perror("strdup");
            exit(1);
        }
        for ( p = strtok(row, SP_CHARS); p != NULL; p = strtok(NULL, SP_CHARS) ){
            ++(*counters[i]);
            if ( ( counters[i] = realloc(counters[i], sizeof(int) * (*counters[i] + 1)) ) == NULL ){
                perror("realloc");
                exit(1);
            }
            counters[i][*counters[i]] = strlen(p);
        }
        free(row);
    }
 
    printf("\nYou wrote:\n");
    for ( i = 0; i < cntRows; ++i )
        printf("%s\n", rows[i]);
    printf("\nLength of words:\n");
 
    for ( i = 0; i < cntRows; ++i ){
        for ( j = 1; j <= *counters[i]; ++j )
            printf("%d\t", counters[i][j]);
        printf("\n");
    }
 
    for ( i = 0; i < cntRows; ++i ){
        free(rows[i]);
        free(counters[i]);
    }
 
    exit(0);
}
 
Текущее время: 15:58. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru