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

Задачи для тренировки и лучшего понимания - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Теория плагинов http://www.cyberforum.ru/cpp/thread123914.html
Всем привет. Для одной моей проги, нужно реализовать поддержку плагинов. Плагины предполагаются простенькие, написанные на Си. То, что плагин, это просто .so файл - понятно. То, что прога может дергать из .so файла функции - тоже понятно. 1. Непонятно то, как сам плагин сможет дергать функции из программы? 2. Программа написана на С++, но плагины предполагаю писать на Си, во избежания...
C++ ./massdown: /usr/lib/libstdc++.so.6: version `GLIBCXX_3.4.11' not found (required by ./massdown) всем хай! собираю свою программу на новом железе х86_64 долго не получалось скомпилить. при линковке получал вот такое сообщение: relocation R_X86_64_32 against `a local symbol' я так понял, это из-за того что часть библиотек от которых зависит цель, были собраны как 32-ух битные. но с этим вроде все нормально, пересобрал все либы - скомпилировалось. теперь при запуске получаю такое... http://www.cyberforum.ru/cpp/thread98890.html
Как понять этот константный указатель? C++
В общем, имеется класс Cat. Объект класса - SimpleCat. И имеется функция с константым указателем: const SimpleCat* const FunctionTwo(const SimpleCat* const theCat) Что обозначают все эти const? Насколько я понимаю: 1. Константный указатель. 2. Может ссылаться только на FunctionTwo 3. Ничего не изменяет в объекте. 4. Ничего не делает с объектом theCat.
C++ Перехват и подмена вызываемых функций
Здравствуйте. Нужно подменить вызов таких функций как open(), lstat(), stat(), read(), write(), mkdir(), chdir(), getcwd() для определенного процесса. Интересует мнение других. Как бы вы реализовали эту задачу. Спасибо!

Показать сообщение отдельно
Mr.X
Эксперт С++
 Аватар для Mr.X
3021 / 1677 / 265
Регистрация: 03.05.2010
Сообщений: 3,867
10.01.2011, 04: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
82
83
84
//////////////////////////////////////////////////////////////////////////////////////
//Рассмотрим бесконечную вправо и вверх шахматную доску, на которой стоит ферзь. 
//Двое по очереди двигают этого ферзя. Разрешается двигать ферзя только вниз, 
//влево или по диагонали вниз влево. Цель игры – задвинуть ферзя в угол, 
//то есть клетку с координатами (1, 1). На рисунке показаны разрешенные движения ферзя.
//------------------------------------------------------------------------------------
//Требуется написать программу, которая найдет номер игрока, который выиграет 
//при правильной игре.
//Входные данные
//------------------------------------------------------------------------------------
//Входной файл INPUT.TXT содержит координаты ферзя перед первым ходом 
//- два числа M и N, записанные через пробел (1 <= M, N <= 250).
//Выходные данные
//------------------------------------------------------------------------------------
//Выходной файл OUTPUT.TXT должен содержать найденный номер победителя.
//////////////////////////////////////////////////////////////////////////////////////
#include <algorithm>
#include <iostream>
#include <set>
//////////////////////////////////////////////////////////////////////////////////////
typedef std::set<int>  T_int_set;
//////////////////////////////////////////////////////////////////////////////////////
const int  M_MIN = 1;
const int  N_MAX = 250;
//////////////////////////////////////////////////////////////////////////////////////
bool  first_is_winner(int  m, int  n)
{
    if(n > m)
    {
        std::swap(m, n);
    }
    //Утверждение: n <= m.
    //По условию фукнция Шпрага-Гранди равна нулю в угловой клетке.
    //Найдем остальные клетки с первой координатой <= n, в которых она равна нулю.
 
    int Y[N_MAX] = {0};
    T_int_set  values;    
    T_int_set  diagonals;    
    for(int i = 0; i < n; ++i)
    {
        if(   i > 0 
           && Y[i] == 0)
        {
            while(   values     .count(Y[i])
                  || diagonals  .count(Y[i] - i))
            {
                ++Y[i];
            }
 
            if(Y[i] < n)
            {
                Y[Y[i]] = i;
            }
        }
        values     .insert(Y[i]);        
        diagonals  .insert(Y[i] - i);
    }
    return Y[n - 1] != m - 1;
}
//////////////////////////////////////////////////////////////////////////////////////
int main()
{
    std::locale::global(std::locale(""));
    std::cout << "Введите координаты ферзя (M_MIN <= M, N <= N_MAX):"
              << std::endl;
    int m = 0;
    do
    {
        std::cout << "M = ";
        std::cin >> m;
    }while(m < M_MIN);
 
    int n = 0;
    do
    {
        std::cout << "N = ";
        std::cin >> n;
    }while(N_MAX < n);
 
    std::cout << "Победит "
              << (first_is_winner(m, n) ? 1 : 2)
              << "-й игрок."
              << std::endl;
}
 
Текущее время: 22:16. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru