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

STL для новичка! - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Алгоритм ГОСТ 28147-89. После шифрования при записи в файл не корректно записывается конец http://www.cyberforum.ru/cpp-beginners/thread1130906.html
Реализую алгоритм шифрования ГОСТ 28147-89. За основу брал код из этой темы http://www.cyberforum.ru/cryptography/thread611386.html (спасибо PitMagnum за него), но с небольшими переделками. Проблема в том, что после шифрования при записи в файл не корректно записывается конец. А при расшифровании не корректно считывается элемент в B-блоке (младшем блоке) и из-за этого в расшифрованный файл идут...
C++ Получить число в виде комбинаций цифр и пробелов Задачка легкая, но уже долго ломаю над нею голову. Дано натуральное число n=12345791, нужно чтобы виходило группами по три цифры 12 345 791. Помогите пожалуйста. http://www.cyberforum.ru/cpp-beginners/thread1130899.html
Программа составляет разные наборы букв из слова red, который лежит в файле C++
Программа составляет разные наборы букв из слова red, который лежит в файле. Нужно переделать программу с помощью random_shuffle #include <iostream> #include <fstream> #include <string> using namespace std; int main() {
Взять 3 точки так, что бы треугольник с вершинами в этих точках включал в себя все точки 2-го множества C++
даны 2 множества точек, из 1-го взять 3 точки так, что бы треугольник с вершинами в этих точках включал в себя все точки 2-го множества.Без графики я сделал, но не могу правильно вывести всё на экран, в соответствии с масштабом. вот код: #include "stdafx.h" #include <math.h> #include <iostream> #include <stdlib.h> #include <time.h> #include <stdio.h> #include <conio.h> #include "locale.h"
C++ Построить алгоритм AOrd3 двухступенчатой сортировки вектора записей с формированием вектора указателей методом выбора http://www.cyberforum.ru/cpp-beginners/thread1130870.html
У кого нибудь есть примеры программ или кто то может объяснить как эти три программы сделать? 2. Создать алгоритм AOrd2, который сортирует вектор записей VS методом вставки. 3. Сделать С++-программу PC4 (консольное приложение), которая вводит файл ТеплопроводностьГазов.txt вектор, обращается к подпрограмме АOrd2 и выводит результат в текстовый файл. Поле ключей запрашивается с клавиатуры при...
 

Показать сообщение отдельно
yur@
5 / 5 / 2
Регистрация: 06.03.2014
Сообщений: 106

STL для новичка! - C++

27.03.2014, 01:59. Просмотров 339. Ответов 2
Метки (Все метки)

Здравствуйте! подскажите пожалуйста мне, дураку(только начал изучать STL) ответ на такой вопрос! что нужно подставить в 19 строку?
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
#include <string.h>
#include <stdio.h>
#include "list.h"
#include "student.h"
 
int main(){
    printf("\t\t\tSupported commands:\n");
    printf("\t\t\tpb - (push_back) add element to the end of list\n");
    printf("\t\t\tpf - (push_front) add element to the front of list\n");
    printf("\t\t\tdel - delete element for order number\n");
    printf("\t\t\tlist - show all elements in the list\n");
    printf("\t\t\tfind - find student by name\n");
    printf("\t\t\tclear - remove all elements from the list\n");
    printf("\t\t\tsave - save the list to a file using fstream\n");
    printf("\t\t\tload - retrieve a list of the file using fstream\n");
    printf("\t\t\texit - quit from program\n\n");
 
    Student x;
    List<.....> s;
    s.List();
    char cmd[50];
    for (;;){
        printf("enter command>");
        fflush(stdin);
        gets(cmd);
        if (strcmp(cmd, "pb")==0){
            x.getName();
            s.push_back(&x, sizeof(Student));
        }
        if (strcmp(cmd, "pf")==0){
            x.getName();
            s.push_front(&x, sizeof(Student));
        }
        if (strcmp(cmd, "list")==0){
            Student *p;
            s.reset();
            while(s.moveNext()){
                p = (Student*)s.getCurrent();
                x.setName();
            }
        }
        if (strcmp(cmd, "find")==0){
            printf("\nEnter student name:");
            scanf("%s", x.name);
            Student *p;
            p = (Student*)s.find(&x,cmp_student_by_name);
 
            if (p!=NULL){
                printf("\nFound: ");
                printf("%s\t", p->name);
                printf("%d\t", p->order);
                printf("%f\n", p->average_point);
            } else {
                printf("Student does not found\n\n");
            }
        }
        if (strcmp(cmd, "clear")==0){
            s.clear(); // Уничтожаем все элементы и освобождаем память
        }
        if (strcmp(cmd, "exit")==0){
           break;
        }
        if (strcmp(cmd, "del")==0){
            int i;
                printf("Input order number: ");
                scanf("%d", &i);
                s.del(i);
            }
        if (strcmp(cmd, "save")==0){
            string l="info.txt";
            s.saveTo(l,sizeof(Student));
        }
        if (strcmp(cmd, "load")==0){
             s.loadFrom("info.txt",sizeof(Student));
        }
 
        }
 
    s.clear();
    return 0;
}
Добавлено через 1 минуту
Извините забыл...
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
template <class T>
class List {
 
    typedef struct l_node{
        T *data;        // Указатель на данные
        l_node *next;   // Указатель на следующий элемент
    } list_node;
    private:
        list_node *head; // Указатель на голову списка
        list_node *current; // Указатель на текущий элемент списка
        int list_size;      // Кол-во элементов списка
        T tmp;
    public:
        List();
        ~List();
        // Возвращает кол-во элементов в списке
        int getListSize();
        // Добавление в список
        bool push_back(const T &data);
        bool push_front(const T &data);
        // Удаление i-того элемента списка
        bool del(int i);
        // Удаление всех элементов списка list,
        // освобождение памяти.
        void clear();
        // Сброс внутреннего указателя списка.
        void reset();
        // Перемещает внутренний указатель списка list на следующий элемент.
        bool moveNext();
        // Возвращает указатель на данные текущего элемента списка,
        // либо NULL - если текущий элемент не существует.
        const T &getCurrent();
        // Возвращает true если элемент найден
        // результат поиска должен быть записан в параметр result
        bool find(T &val, T &result);
        // Сохраняет список в файл с именем fileName
        // возвращает false в случае ошибки
        bool saveTo(const string &fileName);
        // Загружает список из файла с именем fileName
        bool loadFrom(const string &fileName);
};
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru