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

строки в с - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Файлы данных http://www.cyberforum.ru/cpp-beginners/thread85650.html
вОТ задачка! NSI ( нормативно-справочная информация) для расчета заработной платы. TAB - табельный номер; FIO - Фамилия И.О. работника; ...
C++ Как загнать строку в элемент списка? Здравствуйте! есть строка *str есть структура struct a {name char;} все это нужно оформить для списка, а для этого нужно конвертировать строку так, чтобы ее можно было присвоить элементу... http://www.cyberforum.ru/cpp-beginners/thread85648.html
C++ Call to undefined function 'pow'
Есть код // Рис. 2.21: fig02_21.cpp // Вычисление сложного процесса #include<iostream> using std::cout; using std::endl; using std::ios;
C++ Одномерный массив
В одномерном массиве, состоящем из n вещественных элементов, вычислить: 1) номер минимального по модулю элемента массива; 2) сумму модулей элементов массива, расположенных после первого...
C++ Массив http://www.cyberforum.ru/cpp-beginners/thread85639.html
Помогите решить плс!(только как можно простымспсобом , без всяких там сложных библиотек) //1. объявить переменную указатель int*ptr; //2. осущ. ввод целочислен. значений переменной num, которое...
C++ Дeрeво содержит либo дaнныe либo укaзaтeли Всем привет, нужно внести небольшие изменения в код: Элeмeнт дeрeвa coдeржит либo дaнныe (cтрoкa oгрaничeннoй длины), либo укaзaтeли нa прaвoe и лeвoe пoддeрeвья. Стрoки в дeрeвe получаются... подробнее

Показать сообщение отдельно
easybudda
Модератор
Эксперт CЭксперт С++
9622 / 5570 / 946
Регистрация: 25.07.2009
Сообщений: 10,695
14.01.2010, 18:03
kazak, Есть один неприятный момент... Вот, что Ваша програмка может выдавать:
Код
Введите s1: aaa bbb ccc
Введите s2: zzzbbbzzz
Предшествующее слово первому общему слову строк s1, s2
aaa
что как-то неправильно...

Вот немного более замороченный вариант, но без подобной "странности"... Хотя, наверняка других полно.
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
    
#define STRLEN 128
#define SPCHARS " ,.!?\t\n"
 
/* найти слово, предшествующее слову w в строке s */
int main(void){
    char str1[STRLEN], str2[STRLEN], **words, *p;
    int i, count;
    
    printf("String1: ");
    if ( !fgets(str1, sizeof(str1), stdin) )
        exit(1);
    printf("String2: ");
    if ( !fgets(str2, sizeof(str2), stdin) )
        exit(1);
    words = NULL;
    count = 0;
    for ( p = strtok(str1, SPCHARS); p != NULL; p = strtok(NULL, SPCHARS) ){
        if ( ( words = (char**)realloc(words, sizeof(char*) * (count + 1)) ) == NULL )
            exit(1);
        if ( ( words[count] = strdup(p) ) == NULL )
            exit(1);
        ++count;
    }
    
    for ( p = strtok(str2, SPCHARS); p != NULL; p = strtok(NULL, SPCHARS) ){
        for ( i = 0; i < count && strcmp(p, words[i]); ++i )
            ;
        if ( i == count )
            continue;
        else if ( i == 0 ){
            printf("\"%s\" is first word in the String1.\n", p);
            break;
        }
        else {
            printf("Word befor \"%s\" in String1 is \"%s\"\n", p, words[i - 1]);
            break;
        }
    }
    if ( p == NULL )
        printf("No words from String2 found in String1.\n");
    
    for ( i = 0; i < count; ++i )
        free(words[i]);
    free(words);
    exit(0);
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru