Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [PHP]W ilu znakach da się zakodować liczby z przedziału 1-10mln ?
Forum PHP.pl > Forum > Przedszkole
Mesajah
Zastanawiam się, jakiej translacji id używają serwisy (np. youtube) w linkach typu:
http://www.youtube.com/watch?v=kNjyHwySxdI

Jeśli trzeba by zakodować w ten sposób 10 milionów kolejnych liczb (1-10.000.000) to dałoby się to zrobić w 4 znakach czy
trzeba użyć 5 ?

Pomijając czy 4 czy 5 to w jaki sposób najprościej zakodować taką liczbę (np. 3123576) na krótszy symbol znakowy, żeby szybko ją zdekodować.
Są do tego jakieś funkcje, czy trzeba kombinować z zapisywaniem np. każdych 3 cyfr za pomocą 2 znaków, robić jakieś tablice i się w ten sposób bawić ?
Crozin
W URL-u podwaj to liczbę w systemie 36-owym (a-z0-9), a w bazie danych trzymaj "klasyczne" ID - base_convert
thek
Zależy od tego czego użyjesz jako podstawę. Jeśli alfanumeryczną to bierz 36. Jeśli dodatkowo jest case-sensitive to podstawa rośnie do 62 (2*26 znaków + 10 cyfr). W efekcie masz:
dla 36:
1 znak - 36
2 znaki - 1.296
3 znaki - 46.656
4 znaki - 1.679.616
5 znaków - 60.466.176

dla 62:

1 znak - 62
2 znaki - 3.844
3 znaki - 238.328
4 znaki - 14.776.336
5 znaków - 916.132.832

I teraz chyba wiesz czemu niektórzy mówią o 4, a inni o 5 znakach. Chodzi o to czy w zakodowanej liczbie zwraca się uwagę na wielkość znaków.

Jak już wspomniał Crozin, to ja bym tutaj nie uważał na wielkość, bo przeglądarki mogą Ci po drodze to wypaczyć i przez to kompletnie zmienić cel linka. Użyj tak jak radził wyżej Crozin "Base36". Jest pewniejsza, czy też raczej odporniejsza na takie przekłamania, choć zajmuje nieco więcej miejsca, ale to już drobiazg w sumie smile.gif
Mesajah
Dzięki za info.
Skoro więc na 4 znakach da się zakodować 14.776.336 cyfr to już całkiem nieźle (zapomniałem o możliwości
rozróżniania wielkości liter smile.gif
Mesajah
Cytat(thek @ 3.03.2011, 09:17:45 ) *
Jak już wspomniał Crozin, to ja bym tutaj nie uważał na wielkość, bo przeglądarki mogą Ci po drodze to wypaczyć i przez to kompletnie zmienić cel linka. Użyj tak jak radził wyżej Crozin "Base36". Jest pewniejsza, czy też raczej odporniejsza na takie przekłamania, choć zajmuje nieco więcej miejsca, ale to już drobiazg w sumie smile.gif


Aha, rozumiem.
Też czułem, że z tym case sensitive może być problem, więc spróbuje to pominąć (chociaż youtube tak ma).
erix
W sumie, to jeszcze możesz skorzystać z liczby ujemnej... wink.gif
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.