Брутально и бессердечно о программировании и проектировании
ГлавнаяФорумАртПаттерныАнтипаттерныЗаметкиВопрос-ответКнигорецензииСправочная

4. sqrt

Напишите вычисление квадратного корня в compile-time-е. Чтобы усложнить задачу я предлагаю следующее. Если квадратный корень от заданного числа не может быть вычислен в целых, то вашим результатом должно быть ближайшее целое к реальному результату. Обратите внимание, что речь идет именно о ближайшем целом. То есть не ближайшее меньшее результата, а просто ближайшее. Оно может быть как больше, так и меньше реального результата.
Вот мой вариант.
0
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
template <int n, int a, int d>
struct sqrt_impl
{
    enum
    {
        new_a  = (a + (a + d)) / 2,
        new_b  = n / new_a,
        max_ab = new_a > new_b ? new_a : new_b,
        min_ab = new_a < new_b ? new_a : new_b,
        value = sqrt_impl<n, min_ab, max_ab - min_ab>::value
    };
};

template <int n, int x>
struct sqrt_impl<n, x, 0>
{
    enum
    {
        value = x
    };
};

template <int n, int x>
struct sqrt_impl<n, x, 1>
{
    enum
    {
        value = x + 1
    };
};

template <int n>
struct sqrt
{
    enum
    {
        value = sqrt_impl<n, 0, n>::value
    };
};

int main()
{
    int x = sqrt<200>::value;

    return 0;
}
Компилировать в Comeau

Оглавление
Статистика
© 2007—2009 Inside C++ Коммерческие услугиКонтактная информация

надежное продвижение сайта программа продвижения интересные цены только у нас. Uti-Projector.ru - продажа проекторов Sanyo в кредит в Москве, лампы, экраны.. дешевый хостинг mysql, php. Цемент купить и поставка цемента. характеристики ford, продажа ford. стальные двери г клин, металлические двери одинцово