Студопедия — Идея решения задачи
Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Идея решения задачи






При решении поставленной задачи использован способ разбиения целого числа на десятичные разряды. Этим способом можно записать любое целое число до 1040 в виде массива из 41 элемента, где каждый из первых 40 элементов представляет соответствующий разряд числа или незначащий 0. В таком разряде могут находиться числа от 0 до 9, и значит достаточно описать массив типом int, который не является «большим». Последний 41 элемент массива отражает знак числа (знаку «+» соответствует 0, а знаку «–» соответствует 1).

Вводимое число является строкой символов. Для того чтобы преобразовать эту строку в массив целых чисел, используем следующий алгоритм:

1. Рассматриваем первый символ строки.

2. Если это не «–», то 41-му элементу массива присвоим значение 0.

3. Если «–», то:

3.1. 41-му элементу массива присвоим значение 1.

3.2. Удалим первый символ строки.

4. Начнем посимвольный просмотр строки с последнего элемента до первого.

5. Преобразуем каждый символ в целое число.

6. Полученные числа присвоим соответствующим элементам массива.

 

Рис. 5.1. Схема преобразования строки символов в массив целых чисел

Для преобразования символа в целое число используем таблицу ASCII-кодов, в которой числам от 0 до 9 соответствуют коды от 48 до 57. Поэтому для получения целого числа необходимо из кода соответствующего ему символа вычесть 48.

Пользуясь вышеизложенным алгоритмом, по введенной строке символов можно получить запись целого числа без использования «больших» типов. Для реализации требуемых операций над числами в представленной записи разработаны соответствующие алгоритмы.

 







Дата добавления: 2014-11-12; просмотров: 456. Нарушение авторских прав; Мы поможем в написании вашей работы!



Композиция из абстрактных геометрических фигур Данная композиция состоит из линий, штриховки, абстрактных геометрических форм...

Важнейшие способы обработки и анализа рядов динамики Не во всех случаях эмпирические данные рядов динамики позволяют определить тенденцию изменения явления во времени...

ТЕОРЕТИЧЕСКАЯ МЕХАНИКА Статика является частью теоретической механики, изучающей условия, при ко­торых тело находится под действием заданной системы сил...

Теория усилителей. Схема Основная масса современных аналоговых и аналого-цифровых электронных устройств выполняется на специализированных микросхемах...

Растягивание костей и хрящей. Данные способы применимы в случае закрытых зон роста. Врачи-хирурги выяснили...

ФАКТОРЫ, ВЛИЯЮЩИЕ НА ИЗНОС ДЕТАЛЕЙ, И МЕТОДЫ СНИЖЕНИИ СКОРОСТИ ИЗНАШИВАНИЯ Кроме названных причин разрушений и износов, знание которых можно использовать в системе технического обслуживания и ремонта машин для повышения их долговечности, немаловажное значение имеют знания о причинах разрушения деталей в результате старения...

Различие эмпиризма и рационализма Родоначальником эмпиризма стал английский философ Ф. Бэкон. Основной тезис эмпиризма гласит: в разуме нет ничего такого...

Шрифт зодчего Шрифт зодчего состоит из прописных (заглавных), строчных букв и цифр...

Краткая психологическая характеристика возрастных периодов.Первый критический период развития ребенка — период новорожденности Психоаналитики говорят, что это первая травма, которую переживает ребенок, и она настолько сильна, что вся последую­щая жизнь проходит под знаком этой травмы...

РЕВМАТИЧЕСКИЕ БОЛЕЗНИ Ревматические болезни(или диффузные болезни соединительно ткани(ДБСТ))— это группа заболеваний, характеризующихся первичным системным поражением соединительной ткани в связи с нарушением иммунного гомеостаза...

Studopedia.info - Студопедия - 2014-2024 год . (0.012 сек.) русская версия | украинская версия