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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [C#]длинная арифметика, длинная арифметика. системы исчисления 
:(
    Опции темы
Kakadu
Дата 3.3.2009, 18:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



положим есть длинная строка, в которой записано число в десятичной системе. Как реализовать перевод этой строки в систему с основанием Int32.MaxValue? Я как-то запутался совсем, не понимаю как это красиво написать.


--------------------
Добрые мариносы долго кормили украдкой маленьких зерлингов. От этой украдки зерлинги пухли и дохли
PM MAIL   Вверх
Soah
Дата 3.3.2009, 20:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

Репутация: 9
Всего: 54



Kakadu, может я чего-то не понимаю, но какими символами ты будишь представлять числа от 10 до Int32.MaxValue?

Посмотри еще метод Convert.ToString(), может что-то найдёшь.
PM MAIL   Вверх
mrbrooks
Дата 5.3.2009, 09:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


трололомен
****


Профиль
Группа: Завсегдатай
Сообщений: 4259
Регистрация: 4.10.2006
Где: Дол Гулдур

Репутация: 16
Всего: 306



Kakadu, в плане есть строка и ее надо перевести в int?
Код

string str = "78987456478";
int val = Convert.ToInt32(str);


или я тебя не правильно понял?
PM MAIL   Вверх
Kakadu
Дата 5.3.2009, 11:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Нет. положим у меня
Код

string s = "5646543542313131321564654354231313132156465435423131313215646543542313131321564654354231313132156465435423131313215646543542313131321564654354231313132156465435423131313215646543542313131321564654354231313132156465435423131313215646543542313131321";
// потом мы создаем какое-то новое число
BigInteger bi1 = new BigInteger(s);
// и в конструкторе должно построиться массивчик private Int32[] content;
// и каждым элементом массива будет значение в некотором разряде по основанию Int32.MaxValue;




--------------------
Добрые мариносы долго кормили украдкой маленьких зерлингов. От этой украдки зерлинги пухли и дохли
PM MAIL   Вверх
Soah
Дата 5.3.2009, 22:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

Репутация: 9
Всего: 54



Первое что пришло в голову. 
Берём с конца 10-11 символов и конвертируем их в Int64, из этого числа вычитаем Int32.MaxValue,
инкрементируем content, а результат добавляем обратно в строку,
потом опять берём 10-11 символов...
пока в строке не останетца число меньше Int32.MaxValue.
PM MAIL   Вверх
Kakadu
Дата 12.3.2009, 11:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Лично я не понял почему это должно сработать.
Положим у нас исходная строка это "1000000000000". 12 нулей в конце. Давай отщипи 11 символов и покажи как ты отнимишь оттуда Int32.MaxValue.


--------------------
Добрые мариносы долго кормили украдкой маленьких зерлингов. От этой украдки зерлинги пухли и дохли
PM MAIL   Вверх
mrbrooks
Дата 12.3.2009, 14:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


трололомен
****


Профиль
Группа: Завсегдатай
Сообщений: 4259
Регистрация: 4.10.2006
Где: Дол Гулдур

Репутация: 16
Всего: 306



Kakadu, ну отчего же логика в этом есть. Вот смотри int.MaxValue = 2147483647. В строке это занимает 10 символов. Что бы случайно не попасть в значение > int.MaxValue, твой буфер разбиваем по 9 символов и преобразуем в int. Превышения по значению не будет точно.
PM MAIL   Вверх
Kakadu
Дата 12.3.2009, 17:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Цитата(mrbrooks @ 12.3.2009,  14:03)
Kakadu, ну отчего же логика в этом есть. Вот смотри int.MaxValue = 2147483647. В строке это занимает 10 символов. Что бы случайно не попасть в значение > int.MaxValue, твой буфер разбиваем по 9 символов и преобразуем в int. Превышения по значению не будет точно.

да, но если отщеплять по 9 символов, то фактическим основанием будет 10^10, а не Int32.MaxValue;


--------------------
Добрые мариносы долго кормили украдкой маленьких зерлингов. От этой украдки зерлинги пухли и дохли
PM MAIL   Вверх
Soah
Дата 12.3.2009, 22:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

Репутация: 9
Всего: 54



Цитата(Kakadu @  12.3.2009,  11:49 Найти цитируемый пост)
Давай отщипи 11 символов и покажи как ты отнимишь оттуда Int32.MaxValue

легко  smile 
Код

    //String s = "12345678912345678912345";
    String s = "100000000000000000000000";
    Int64 content = 0;

    int iBase = Int32.MaxValue; 
    Int64 partNumber = 0;

    int len = (s.Length >= 17) ? 17 : s.Length;
    partNumber = Int64.Parse(s.ToString().Substring(s.Length - len, len));
    StringBuilder partString = new StringBuilder(s.Substring(0, s.Length - len));

    while (Int64.Parse(partString.ToString()) > 0)
    {
        if(partNumber < iBase)
        {
            for (int i = partString.Length - 1; i >= 0; --i)
                if (partString[i] != '0')
                {
                    --partString[i];
                    break;
                }
                else
                    partString[i] = '9';

                partNumber += 100000000000000000;
        }

        content += partNumber / iBase;
        partNumber %= iBase;
    }

    Console.WriteLine("{0} * {1} + {2} = {3}", content, iBase, partNumber, s);

написал примерно, поэтому алгоритм ещё надо доработать,
к тому же, при больших чисел, алгоритм очень медленный, 
надо подумать над оптимизацией.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

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

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


 




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


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

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