Модераторы: Daevaorn

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> двумерный массив, каждый последущий элемент в 2раза больше 
:(
    Опции темы
zhgutov
Дата 17.10.2007, 14:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 120
Регистрация: 14.12.2004

Репутация: 1
Всего: 2



long double вмещает максимум примерно 10^4932
В экспоненциальной форме. Количество десятичных разрядов будет ограничено примерно 17 знаками. А нужно 31! 2^100 = 1267650600228229401496703205376)) При использовании double получится что-то вроде 1267650600228229400000000000000. Тут либо использовать 128-битную целочисленную арифметику, либо реализовать свой класс.

Добавлено @ 14:39
Если не извращаться:
Код

#include <cstdio>

typedef int Integer;

const int WIDTH = 4;
const int HEIGHT = 4;

int main ()
{
    Integer values [WIDTH][HEIGHT], temp = 1;

    for (int y = 0; y < HEIGHT; ++y)
    {
        for (int x = 0; x < WIDTH; ++x)
        {
            values [x][y] = temp;
            printf ("%d ", temp); // Или как-то иначе...
            temp *= 2;
        }
        printf ("\n");
    }
}


Это сообщение отредактировал(а) zhgutov - 17.10.2007, 14:42
--------------------
Приполз. Увидел. Укусил.
PM MAIL   Вверх
zhgutov
Дата 17.10.2007, 15:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 120
Регистрация: 14.12.2004

Репутация: 1
Всего: 2



А если по приколу, то без использования строк можно использовать что-то типа этого:
Код

unsigned mul (unsigned arg1, unsigned arg2, unsigned* high_ptr)
{
    unsigned _low, _high;
    _asm
    {
        mov    eax, arg1
        mov    ebx, arg2
        mul    ebx
        mov    _low, eax
        mov    _high, edx
    }
    if (high_ptr)
    {
        *high_ptr = _high;
    }
    return _low;
}

А дальше — как в столбик...
--------------------
Приполз. Увидел. Укусил.
PM MAIL   Вверх
akizelokro
Дата 19.10.2007, 07:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Крокодил
**


Профиль
Группа: Участник
Сообщений: 761
Регистрация: 30.7.2007

Репутация: 1
Всего: 5



Цитата

Тут либо использовать 128-битную целочисленную арифметику, либо реализовать свой класс.

Либо скачать библиотеку HIME для работы с huge integers


--------------------
a = a + b; b = a - b; a = a - b;
PM MAIL   Вверх
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1107 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.