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

Нахождение двухстрочных комментариев - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Функция сортировки вектора и списка http://www.cyberforum.ru/cpp-beginners/thread1064118.html
Добрый день, помогите пожалуйста) Суть задания в том, что нужно написать функцию сортировки (Одну!) сразу для вектора и списка без использования итераторов, т.е. в main'е требуется передать в функцию либо объект класса вектора, либо объект класса списка (int main {.....sort (Vector v или List l)}. Сделал с итераторами вот так, но препод попросил сортировать без итераторов: //template...
C++ Найти трехзначные числа от 100 до n, равные сумме кубов своих цифр Найти трехзначные числа от 100 до n, равные сумме кубов своих цифр. (написать три программы с использованием всех видов цикла) http://www.cyberforum.ru/cpp-beginners/thread1064113.html
C++ Неправильно работает функция
void FreeTop( Tree *&tree ) { if( tree->d == NULL )delete tree; else FreeTop( tree->d ); } это моя функция освобождения памяти самого верхнего узла дерева. но почему то когда вызываю вот тот код: while( tree != NULL ){ FreeTop(tree);
C++ Проверить, образуют ли 4 числа арифметическую, геометрическую прогрессию, или не образуют никакой прогрессии
Создать программу, с помощью которой можно выяснить, образуется из заданных четырех чисел арифметическая прогрессия, геометрическая прогрессия или совсем не образуется. Если какая-то образуется, то найти ее разницу или знаменатель и сумму первых десяти членов, а если не образуется никакая, то заменить все введенные числа на вдвое меньше. На экран вывести соответствующие комментарии с объяснением...
C++ Определить материал с минимальной плотностью http://www.cyberforum.ru/cpp-beginners/thread1064094.html
Всем добрый день,помогите кто может.Чего здесь не хватает или не правильно,что-то.? Неправильно выводит материал с минимальной плотностью. Вот условие задачи: Известны данные о массе и объеме 30-ти предметов, изготовленных из различных материалов. Определить материал с минимальной плотностью. Вот код: #pragma hdrstop #include <stdio.h> #pragma argsused struct DATA{
C++ Дана строка символов. Проверьте,является ли данная строка палиндромом Парни нужна помощь,нужен код решения этой задачи на языке с++. Дана строка символов. Проверьте,является ли данная строка палиндромом. подробнее

Показать сообщение отдельно
0x10
2425 / 1597 / 232
Регистрация: 24.11.2012
Сообщений: 3,919
06.01.2014, 20:58     Нахождение двухстрочных комментариев
Во-первых, в первом же посте есть пример работы с std::cin.getline() - что мешает подправить код с его использованием? Уже по готовому.
Во-вторых, пусть и не в этом дело, но почему все так упорно используют шестой билдер? Я гоню или ему уже больше 10 лет?
В-третьих, ок, пофиг, раз такое дело, переезжаем частично на плюсы.
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
/*\
|*| Этот комментарий добавлен исключительно для демонстрации работы на таких
|*| извращенных входных данных.
|*|
|*| (C) 2014
\*/
 
#include <cstdio>
#include <cstdlib>
#include <cstring>
 
#include <iostream>
 
int main()
{
    const int line_len = 512;
    char code_line[line_len];
 
    int in_comment = 0; /* true если в процессе поиска конца комментария */
 
    const char* const comment_open_tag = "/""*";
    const char* const comment_close_tag = "*""/";
 
    const char* comment_begin;
    const char* comment_end;
 
    /* Задача чисто сишная, будем пользоваться сишными функциями */
    while (std::cin.getline(code_line, line_len))
    {
        if (!in_comment)
        {
            /* Попытаемся найти начало комментария в текущей строке */
            comment_begin = strstr(code_line, comment_open_tag);
 
            /*
             * Если нашли, возможны варианты:
             * 1. Комментарий заканчивается в этой же строке.
             * 2. Комментарий заканчивается в другой строке
             */
            if (comment_begin)
            {
                comment_end = strstr(comment_begin, comment_close_tag);
 
                /* Нашли конец комментария в этой же строке */
                if (comment_end)
                {
                    /* хитрый синтаксис для вывода части строки */
                    printf("%.*s\n", (int)(comment_end - comment_begin + 2),
                        comment_begin);
                }
                else
                {
                    printf("%s\n", code_line);
                    /* иначе запомним, что нужно найти конец комментария */
                    in_comment = 1;
                }
            }
        }
        else
        {
            comment_end = strstr(comment_begin, comment_close_tag);
            if (comment_end)
            {
                printf("%.*s\n", (int)(comment_end - code_line + 2), code_line);
                in_comment = 0;
            }
            else
            {
                printf("%s\n", code_line);
            }
        }
    }
 
    return 0;
}
 
Текущее время: 15:59. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru