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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Файлы данных http://www.cyberforum.ru/cpp-beginners/thread85650.html
вОТ задачка! NSI ( нормативно-справочная информация) для расчета заработной платы. TAB - табельный номер; FIO - Фамилия И.О. работника; TARIF - оплата за один час работы;
C++ Как загнать строку в элемент списка? Здравствуйте! есть строка *str есть структура struct a {name char;} все это нужно оформить для списка, а для этого нужно конвертировать строку так, чтобы ее можно было присвоить элементу списка. Помогите, плиз! Добавлено через 3 часа 52 минуты Все решается через strcpy, спасибо! 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, которое определяет длину динам. //размещения одномер массива, контролир. переменной ptr. //3.заполняет на предыдущем шаге динам. массив псевдо.числами. из ( использовать // srand и rand. //4.объяв...
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 получаются упoрядoчeны. Нaпиcaть функцию включeния нoвoй cтрoки. Обрaтить внимaниe нa тo, чтo элeмeнт c укaзaтeлями нe coдeржит дaнных, и при включeнии нoвoй вeршины вeршину c дaнными cлeдуeт зaмeнить нa... подробнее

Показать сообщение отдельно
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9383 / 5433 / 916
Регистрация: 25.07.2009
Сообщений: 10,428
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);
}
 
Текущее время: 18:48. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru