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

ООП. Напечатать слова, отличные от последнего слова, предварительно преобразовав каждое из них по правилу - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Определить, является ли заданная матрица A(n,n) ортогональной http://www.cyberforum.ru/cpp-beginners/thread1130765.html
квадратная матрица A называется ортогональной, если A транспонированная=обратной A . Определить, является ли заданная матрица A(n,n) ортогональной.
C++ Найти слова которые могут быть полностью сложены из других слов,сцепление слов(конкатенация) найти слова которые могут быть полностью сложены из других слов,сцепление слов(конкатенация) http://www.cyberforum.ru/cpp-beginners/thread1130761.html
C++ Определить номер минимального простого числа до и после упорядочивания массива
Упорядочить массив целых положительных чисел по возрастанию, определить номер минимального простого числа до и после упорядочивания массива. Создать функции для сортировки массива и определения простого числа. #include <iostream> #include <time.h> #include<stdlib.h> #include <iomanip> bool IsSimple(int); void printArray(int, int);
C++ Не могу разобраться с наследованием
есть клас class Liquid{ private: string name; float density; public: Liquid(){ name = "unknow"; density = 0;
C++ Программа работает но не выводит таблицу, результат выбора и сортировки http://www.cyberforum.ru/cpp-beginners/thread1130729.html
Помогите пожалуйста. Программа работает но не выводит таблицу, результат выбора и сортировки. #include<stdio.h> #include<conio.h> #include<string.h> #include <iomanip.h> struct STUDENT {char fam; char name; char pol; int vozrast; int rayting;};
C++ Вывод массива во время отладки можно ли в поле Watch во время пошаговой отладки программы выводить весь массив? подскажите, пожалуйста, буду благодарен подробнее

Показать сообщение отдельно
uburuntu
 Аватар для uburuntu
94 / 94 / 29
Регистрация: 04.10.2012
Сообщений: 188
26.03.2014, 22:46     ООП. Напечатать слова, отличные от последнего слова, предварительно преобразовав каждое из них по правилу
Достал из закутков такую функцию:
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
#include <string.h>
 
int parse (char *s, const char *sep, char **words, int max_words)
    {
        char *p = s;
        int len_remain = strlen(s);
        int count = 0;
        int i_sep, i_word;
        
        while (1)
            {
                i_word = strspn(p, sep);
                for (int i = 1; i <= i_word; i++) *p++ = 0;
                words[count++] = p;
                
                if (i_word == len_remain) break;
                len_remain -= i_word;
                
                i_sep = strcspn(p, sep);
                if (i_sep == len_remain) break;
                len_remain -= i_sep;
                
                p += i_sep;
                
                if (count == max_words) break;
            }
            
        return count-1;
    }
Она разбивает входную строку s на слова, разделенные символами из sep (сепараторы, в твоем случае это просто пробел) и заносит эти слова в массив строк words. И возвращает количество получившихся слов.
Я бы на твоем месте сделал бы так: разбил строку, потом сравнивал бы words[n-1] со всеми остальными.

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