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

Правила вложенности тегов html (html разметка на С++) - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Дан двумерный массив A размера m×n. Найти количество столбцов, где все элементы упорядочены по возрастанию http://www.cyberforum.ru/cpp-beginners/thread1060123.html
Преподаватель сказал, что подсчитывается количество столбцов с упорядоченными по неубыванию элементами, а по условию задачи надо было найти количество столбцов с упорядоченными по возрастанию элементами. Как это исправить? Помогите, пожалуйста. Завтра уже сдавать! #include <cstdlib> #include <iostream> using namespace std; int main() { int n;
C++ как найти последний символ в строке добрый день. мне нужно проверить условие, если последний символ в строке цифра, то строки больше не выводятся. так вот, как же найти этот последний символ в строке? у меня строка char tmp ; http://www.cyberforum.ru/cpp-beginners/thread1060116.html
C++ виртуальные методы.наследование от базового класса
определить класс пар целых чисел,определить для него операции сложения и вычитания по правилам (a,b)+(c,d)=(a+c,b+d),(a,b)-(c,d)=(a-c,b-d), а также методы ввода и вывода. На основе этого класса определить класс денежных сумм(руб.коп).Для этого класса переопределить методы базового класса,а так же определить методы умножения и деления на заданное вещественно число. #include "stdafx.h" #include...
C++ Объясните код (задача о восьми ферзях)
Нужно расписать код, каждую строчку, что делает та или иная функция в данной программе и тд. Очень срочно, буду очень благодарен. #include <iostream> using namespace std; int board; void setQueen(int i, int j) { for (int x = 0; x < 8; ++x)
C++ Как сделать односвязный список в узле дерева http://www.cyberforum.ru/cpp-beginners/thread1060082.html
Ребят подскажите, пожалуйста, как сделать односвязный список в узле дерева? Нужно написать программу учета нарушений ПДД. Для каждого а/м нужно хранить в базе список нарушений. Для каждого нарушения фиксируется дата, время, вид нарушения и размер штрафа. При оплате всех штрафов а/м удаляется из базы. Ключом узла д/б номер а/м. код списка: list.h #ifndef LIST_H #define LIST_H #include...
C++ Перевод из 2-ной в 8-ную систему счисления и обратно помогите написать код, как перевести число из 2 в 8 систему счисления и обратно? подробнее

Показать сообщение отдельно
cp
0 / 0 / 0
Регистрация: 29.12.2013
Сообщений: 3

Правила вложенности тегов html (html разметка на С++) - C++

29.12.2013, 16:43. Просмотров 1005. Ответов 6
Метки (Все метки)

Смысл программы: создание html разметки (добавление, удаление тегов)
Подскажите, как и где реализовать правила вложенности тегов? (Например, тег <h1> нельзя вставить внутрь ссылки <a>, <p> нельзя вставить в <em>, и т.д.)

Код (VS 2010):
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
#include "stdafx.h"
#include <iostream>
#include <string>
#include <sstream>
 
using namespace std;
 
class elem {
    elem *next_elem;
    friend class list;
    friend class iter;
public:
    virtual string str() = 0;
};
 
class iter {
    elem *current_elem;
    friend class list;
public:
    iter(): current_elem(0) {}
    const iter &operator++() {
        if (current_elem)
            current_elem = current_elem->next_elem;
        return *this;
    }
    elem &operator*() { return *current_elem; }
    elem *operator->() { return current_elem; }
    bool operator!=(iter v) {
        return current_elem != v.current_elem;
    }
};
 
class list {
    elem *first_elem;
public:
    list(): first_elem(0) { }
    void push_back(elem *p) { // р-  к которому мы добавляем
        elem *e = 0;
        for (iter i = begin(); i != end(); ++i)
            e = &*i;
        if (e) // ЕСЛИ есть елементы то в конец
            e->next_elem = p;
        else
            first_elem = p; // если нет то в начало
        p->next_elem = 0;// убирается
    }
    iter begin() {
        iter tmp;
        tmp.current_elem = first_elem;
        return tmp;
    }
    iter end() {
        iter tmp;
        tmp.current_elem = 0;
        return tmp;
    }
};
 
class text: public elem {
    string s;
public:
    text(string ss): s(ss) {}
    string str() { return s; }
};
 
class tag: public elem {
    string name;
    list content;
protected:
    string content_str() {
        string s;
        for (iter i = content.begin(); i != content.end(); ++i)
            s += i->str();
        return s;
     }
public:
    tag(string s): name(s) {}
    tag &push_back(elem *e) {
        content.push_back(e);
        return *this;
    }
    string str() {
        return
            "<" + name + ">" +
            content_str() +
            "</" + name + ">";
    }
};
 
class p: public tag {
    public:
        p(): tag("p") {}
};
 
class em: public tag {
    public:
        em(): tag("em") {}
};
 
class strong: public tag {
public:
    strong(): tag("strong") {}
};
 
class a: public tag {
    string href;
public:
    a(string s): tag("a"), href(s) {}
    string str() {
        return
            "<a href=\"" + href + "\">" +
            content_str() +
            "</a>";
    }
};
 
int main()
{
    p p1; //создаем тег p
    em em1; //создаем тег p
 
    em1.push_back(new text("mir")); //вставляем text в em
    p1.push_back(&em1); //вставляем em в p
 
    cout << p1.str() << endl;
 
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru