Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: Запись числа в научной нотации с известным порядком
Форумы портала PHP.SU » » Хранение данных, их вывод и обработка » Запись числа в научной нотации с известным порядком

Страниц (1): [1]
 

1. Алекс7 - 20 Июля, 2017 - 22:46:38 - перейти к сообщению
Добрый день.
Хочу уменьшить длину строки, которая содержит массив чисел с плавающей запятой. В массиве около 200 - 300 чисел.
Все числа одного порядка.
Я определяю этот порядок и далее хочу записать все числа в виде последовательности пяти цифр (мне достаточно такой точности).

Например, есть числа 1.367892e8; 5.45678921e8; 2.43216789e8 и т.д.
я хочу получить следующее:
8 (порядок этих чисел); 13679; 54568; 24322 и т.д.
Вот пока не пойму, как это сделать - может, сначала записать все числа в соответствующем порядке - то есть 13679e4; 54568e4; 24322e4, а затем убрать порядок? Если да, то как это сделать средствами PHP с максимальной производительностью?
Или просто умножать все числа на 10 в степени порядок - 4? То есть в данном примере все числа умножить на 10^(8-4)=10^4=10000? Ведь порядок мне известен заранее?
Или существуют более удобные варианты? Главный фактор - минимальное время операции.
Заранее большое спасибо за помошь.
2. Мелкий - 20 Июля, 2017 - 23:35:23 - перейти к сообщению
Самый быстрый код - тот которого нет. Иначе говоря: зачем?

В php нет int3 (а в int2 гарантированно 5 значащих цифр не влезают). Есть только int, и тот зависит от того, где и как собрали PHP - 4 или 8 байт. Следовательно для пяти значащих цифр вы абсолютно ничего не получите по памяти относительно стандартного, исконно научного float.

В строковом представлении (для сериализации, сохранения на диск, передачи по сети или ещё чего) - используйте как есть бинарный формат числа. Вам всё равно необходима реализация и читателя и писателя. Используйте стандартный ieee754. pack, unpack. 4 байта float даже без плясок с экспонентой короче на целый байт 5 цифр.

Как выводить всегда в экспоненте - вопрос именно вывода. printf %e %E %g %G

 

Powered by ExBB FM 1.0 RC1