Faktoradik: Perbedaan antara revisi

Konten dihapus Konten ditambahkan
RPras (bicara | kontrib)
kTidak ada ringkasan suntingan
InternetArchiveBot (bicara | kontrib)
Rescuing 1 sources and tagging 0 as dead.) #IABot (v2.0.9.5
 
(19 revisi perantara oleh 15 pengguna tidak ditampilkan)
Baris 1:
{{tanpa referensi}}
'''Faktoradik''' adalah sebuah [[sistem bilangan]] yang setiap posisi [[angka]] memiliki basis sesuai dengan [[faktorial]] dari posisinya. Sistem bilangan ini memungkinkan untuk membangkitkan permutasi dalam urutan [[leksikografik]].
 
Baris 4 ⟶ 5:
''a''<sub>n</sub>...''a''<sub>4</sub>''a''<sub>3</sub>''a''<sub>2</sub>''a''<sub>1</sub>''a''<sub>0</sub>, dengan setiap bilangan ''a''<sub>i</sub> bersifat:
 
:<math>a_i \in \mathbb{N}</math>
 
dan
 
:<math>0 \leq a_i \leq i</math>
 
== Nilai faktoradik ==
Nilai sebuah faktoradik ''a''<sub>n</sub>...''a''<sub>4</sub>''a''<sub>3</sub>''a''<sub>2</sub>''a''<sub>1</sub>''a''<sub>0</sub> dapat dengan mudah didapat menggunakan formula:
 
:<math>\sum_{i=0}^n a_i.i! </math>
 
Sebagai contoh, bilangan 2,1,1,1,0
 
Posisi setiap bilangan, sama seperti pada sistem bilangan posisional lainnya, dinomori mulai dari 0 dari sebelah kanan.
:{| class="wikitable"
|-
| Bilangan ke
Baris 49 ⟶ 50:
 
Di bawah ini adalah daftar 24 faktoradik pertama beserta nilainya:
:{| class="wikitable"
|-
! Faktoradik
Baris 115 ⟶ 116:
|}
 
== Mendapatkan Faktoradik dari Sembarang Bilangan ==
Suatu faktoradik bisa diperoleh dari sembarang bilangan <math>n</math> dengan algoritmaalgoritme sebagai berikut:
 
# Cari <math>i !</math> terbesar di mana <math>i ! < n</math>
Baris 122 ⟶ 123:
# <math>d</math> adalah digit faktoradik ke-<math>i</math>, yaitu <math>a_i</math>
# Ulangi dari langkah kedua, dengan <math>m</math>(sisa bagi) menggantikan <math>n</math>, dan <math>i - 1</math> menggantikan <math>i</math>.
# AlgoritmaAlgoritme selesai jika <math>i</math> sudah mencapai 0.
 
Ketika berakhir, algoritmaalgoritme ini akan menghasilkan deretan faktoradik ''a''<sub>n</sub>...''a''<sub>4</sub>''a''<sub>3</sub>''a''<sub>2</sub>''a''<sub>1</sub>''a''<sub>0</sub>.
 
== Permutasi ==
=== Membentuk Permutasi berdasarkan Faktoradik ===
===Bilangan Inversi===
 
===Membentuk Permutasi berdasarkan Faktoradik===
Pertama-tama kita harus membuat kesepakatan mengenai indeks. Indeks untuk untai dimulai dengan indeks 0 dari kiri.
:{| class="wikitable"
|-
| Untai
Baris 151 ⟶ 150:
| 6
|}
Disediakan sebuah untai <math>s</math>, dan sebuah faktoradik <math>f</math>, maka algoritmaalgoritme untuk menghasilkan sebuah permutasi dari <math>s</math> adalah:
# Sediakan satu tempat, yaitu <math>s'</math> untuk menampung untai hasil permutasi
# Mulai dari digit <math>f</math> paling kiri (digit dengan indeks posisi paling besar):
#* Ambil huruf dari <math>s</math> di posisi <math>f_i</math>, pindahkan ke <math>s'</math>
# Ulangi hingga tidak ada lagi huruf pada untai <math>s</math>
Ketika algoritmaalgoritme ini selesai, <math>s'</math> akan merupakan permutasi dari <math>s</math> yang sesuai dengan <math>f</math>
 
Sebagai contoh, untuk menghasilkan permutasi dari '''abcdefg''', dengan indeks faktoradik 5341200 dengan algoritmaalgoritme tersebut, diberikan:
 
:<math>s = \mathbf{abcdefg}</math>
dan
:<math>f = (5, 3, 4, 1, 2, 0, 0)</math>
 
Disediakan <math>s' = \epsilon</math> (masih kosong).
 
:{| class="wikitable"
|-
| Untai
Baris 191 ⟶ 190:
Dengan <math>s</math> sekarang menjadi:
 
:{| class="wikitable"
|-
| Untai
Baris 212 ⟶ 211:
Bilangan kedua dari <math>f</math>, yaitu <math>f_5</math> adalah 3, maka pindahkan huruf ke-3 pada untai <math>s</math> ke untai <math>s'</math>. Maka kondisinya menjadi <math>s = \mathbf{abceg}</math> dan <math>s' = \mathbf{fd}</math>
 
:{| class="wikitable"
|-
| Untai
Baris 229 ⟶ 228:
|}
 
Dan seterusnya, yang jika dituliskan sekaligus adalah seperti ini:
:{| class="wikitable"
! i
! <math>f_i</math>
Baris 272 ⟶ 271:
|}
 
== Kode-kode program ==
=== Kode program untuk membangkitkan faktoradik ===
==== Pascal ====
 
FMax := CariFaktorialTerbesar(Bilangan);
Sisa := Bilangan;
'''for''' i := FMax '''downto''' 0 '''do'''
'''begin'''
f := Faktorial(i);
A[i] := Sisa '''div''' f;
Sisa := Sisa '''mod''' f;
'''end''';
 
=== Kode untuk membangkitkan permutasi dari faktoradik ===
==== Pascal ====
 
'''function''' Permutasi(Untai: STRING; Faktoradik: '''array of''' INTEGER): STRING;
Baris 304:
'''end''';
 
== Lihat Jugapula ==
* [[Kombinadik]]
* [[Permutasi]]
* [[Bilangan Inversi]]
* [[Sistem Bilanganbilangan]]
 
== Pranala Luarluar ==
[http://msdn2.microsoft.com/en-us/library/aa302371.aspx Using Permutations in .NET for Improved Systems Security] {{Webarchive|url=https://web.archive.org/web/20080412030829/http://msdn2.microsoft.com/en-us/library/aa302371.aspx |date=2008-04-12 }}
 
[[Kategori:Sistem bilangan]]
[[Kategori:KombinatorikKombinatorika]]
 
[[en:Factoradic]]