1 00:00:07,260 --> 00:00:09,180 [Powered by Google Translate] Mari kita bicara tentang structs. 2 00:00:09,180 --> 00:00:12,130 Structs memberikan kami cara untuk mengelompokkan sekelompok variabel bersama-sama 3 00:00:12,130 --> 00:00:14,350 ke dalam suatu paket yang bagus. 4 00:00:14,350 --> 00:00:17,020 Ini mungkin paling mudah untuk melihat contoh langsung, 5 00:00:17,020 --> 00:00:20,030 jadi kita katakan struct, 6 00:00:20,030 --> 00:00:23,340 kemudian membuka brace keriting, 7 00:00:23,340 --> 00:00:26,630 dan dalam struct ini, kita akan memiliki usia int, 8 00:00:28,920 --> 00:00:31,350 nama char *, 9 00:00:31,350 --> 00:00:34,670 dan hanya itu. 10 00:00:37,350 --> 00:00:40,650 Ini mungkin tampak aneh dengan titik koma setelah tanda kurung kurawal, 11 00:00:40,650 --> 00:00:43,620 tapi itu sebenarnya diperlukan dengan struct. 12 00:00:43,620 --> 00:00:46,270 Tipe apapun yang benar bisa pergi dalam definisi struct. 13 00:00:46,270 --> 00:00:49,530 Di sini, kita telah menggunakan int dan char *, 14 00:00:49,530 --> 00:00:52,610 tetapi Anda juga bisa menggunakan array, katakanlah, 100 elemen 15 00:00:52,610 --> 00:00:54,910 atau bahkan struct lain. 16 00:00:54,910 --> 00:00:56,960 Bila Anda menggunakan structs di C, 17 00:00:56,960 --> 00:00:58,430 Anda sedang menciptakan jenis baru 18 00:00:58,430 --> 00:01:00,860 keluar dari koleksi jenis lainnya. 19 00:01:00,860 --> 00:01:02,620 Di sini, kita membuat jenis baru 20 00:01:02,620 --> 00:01:05,060 keluar dari integer dan char *. 21 00:01:05,060 --> 00:01:07,400 Seperti yang akan kita lihat nanti, jenis struct 22 00:01:07,400 --> 00:01:10,700 adalah dalam banyak cara yang setara dengan jenis lain yang Anda terbiasa. 23 00:01:10,700 --> 00:01:13,310 Biasanya, saya akan membandingkan bagaimana tipe struct 24 00:01:13,310 --> 00:01:15,790 mirip dengan tipe integer. 25 00:01:15,790 --> 00:01:18,520 Sedangkan kode yang kami tulis adalah C berlaku, 26 00:01:18,520 --> 00:01:20,320 itu tidak terlalu berguna, 27 00:01:20,320 --> 00:01:22,340 dan dentang akan memberi kita peringatan. 28 00:01:22,340 --> 00:01:24,970 Ingat bagaimana structs dan yang mirip? 29 00:01:24,970 --> 00:01:26,710 Nah, kita pada dasarnya hanya mengatakan 30 00:01:27,840 --> 00:01:30,060 int, 31 00:01:30,060 --> 00:01:33,140 yang bukan merupakan garis yang sangat membantu. 32 00:01:33,140 --> 00:01:35,760 Jadi mari kita benar-benar mendeklarasikan variabel dari jenis yang 33 00:01:35,760 --> 00:01:38,760 dengan memberikan nama sebelum titik koma. 34 00:01:42,170 --> 00:01:45,000 Kami akan memanggil si mahasiswa variabel. 35 00:01:48,190 --> 00:01:51,350 Sekarang kita sudah menyatakan seorang mahasiswa disebut variabel 36 00:01:51,350 --> 00:01:53,980 dengan tipe yang diberikan oleh struct. 37 00:01:53,980 --> 00:01:56,730 Bagaimana kita bisa sampai ke variabel di dalam struct? 38 00:01:56,730 --> 00:01:59,040 Secara teknis, nama-nama untuk variabel-variabel 39 00:01:59,040 --> 00:02:01,070 adalah anggota. 40 00:02:01,070 --> 00:02:04,000 Untuk mengakses setiap anggota tertentu dalam struct mahasiswa, 41 00:02:04,000 --> 00:02:06,440 Anda menambahkan sebuah titik ke nama variabel, 42 00:02:06,440 --> 00:02:08,860 diikuti oleh nama anggota yang Anda inginkan. 43 00:02:08,860 --> 00:02:11,690 Jadi di sini, hanya 2 kemungkinan berlaku 44 00:02:11,690 --> 00:02:17,760 adalah student.age 45 00:02:17,760 --> 00:02:24,460 dan student.name. 46 00:02:24,460 --> 00:02:26,820 Dan kita bisa melakukan sesuatu seperti 47 00:02:26,820 --> 00:02:30,320 student.age = 12 48 00:02:30,320 --> 00:02:39,310 dan student.name = mahasiswa. 49 00:02:39,310 --> 00:02:42,580 Sekarang bagaimana jika kita ingin membuat mahasiswa kedua? 50 00:02:42,580 --> 00:02:44,760 Anda mungkin berpikir untuk menyalin dan menyisipkan baris-baris 51 00:02:44,760 --> 00:02:48,110 dan mengubah siswa kepada siswa 2 atau sesuatu, 52 00:02:48,110 --> 00:02:50,090 dan itu akan bekerja, 53 00:02:50,090 --> 00:02:52,670 tetapi secara teknis, pelajar dan mahasiswa 2 54 00:02:52,670 --> 00:02:54,540 tidak memiliki tipe yang sama. 55 00:02:54,540 --> 00:02:56,940 Lihat, Anda tidak akan dapat menetapkan mereka untuk satu sama lain. 56 00:02:56,940 --> 00:02:58,560 Hal ini karena, sejauh ini, 57 00:02:58,560 --> 00:03:00,950 struct Anda telah anonim. 58 00:03:00,950 --> 00:03:02,290 Kita perlu untuk memberikan nama. 59 00:03:02,290 --> 00:03:04,420 Untuk melakukan itu, kita masukkan nama struct 60 00:03:04,420 --> 00:03:06,950 setelah struct kata. 61 00:03:09,440 --> 00:03:11,170 mahasiswa, 62 00:03:11,170 --> 00:03:14,680 diikuti oleh definisi. 63 00:03:16,500 --> 00:03:18,940 Kita masih bisa segera mendeklarasikan variabel jenis 64 00:03:18,940 --> 00:03:21,570 struct mahasiswa, seperti yang kami lakukan sebelumnya. 65 00:03:24,320 --> 00:03:28,360 Kita akan menyebutnya S1 66 00:03:28,590 --> 00:03:30,760 Dengan memberikan struct nama, 67 00:03:30,760 --> 00:03:33,050 kita sekarang dapat menggunakan struct mahasiswa 68 00:03:33,050 --> 00:03:36,950 di hampir dengan cara yang sama kita akan menggunakan int. 69 00:03:36,950 --> 00:03:39,580 Jadi kita bisa mendeklarasikan variabel mahasiswa tipe struct, 70 00:03:39,580 --> 00:03:42,360 seperti 71 00:03:42,360 --> 00:03:49,500 struct mahasiswa S2. 72 00:03:51,020 --> 00:03:55,130 Seperti array, struct memberikan sintaks inisialisasi pintas, 73 00:03:55,130 --> 00:03:58,670 sehingga kita dapat mengatakan, struct mahasiswa S2 74 00:03:58,670 --> 00:04:01,420 sama 75 00:04:01,420 --> 00:04:06,040 kiri keriting brace 3, S2. 76 00:04:09,210 --> 00:04:12,600 Di sini, S2.age akan 3, 77 00:04:12,600 --> 00:04:15,910 dan S2.name akan mengarah ke S2. 78 00:04:15,910 --> 00:04:19,149 Pikirkan semua hal yang dapat Anda lakukan dengan tipe int 79 00:04:19,149 --> 00:04:22,460 dan sebagian besar dari mereka dapat Anda lakukan dengan tipe mahasiswa struct. 80 00:04:22,460 --> 00:04:26,060 Kita dapat menggunakan struct mahasiswa sebagai jenis parameter fungsi. 81 00:04:26,060 --> 00:04:28,790 Kita dapat menggunakan mahasiswa struct dalam struct baru. 82 00:04:28,790 --> 00:04:31,010 Kita dapat memiliki pointer ke struct mahasiswa. 83 00:04:31,010 --> 00:04:33,540 Kita bisa melakukan ukuran mahasiswa struct. 84 00:04:33,540 --> 00:04:35,510 Struct mahasiswa adalah tipe 85 00:04:35,510 --> 00:04:38,030 seperti int adalah tipe. 86 00:04:38,030 --> 00:04:40,540 Kita juga dapat menetapkan S1 ke S2 87 00:04:40,540 --> 00:04:43,760 karena keduanya adalah dari jenis yang sama, sehingga kami dapat melakukan 88 00:04:44,390 --> 00:04:47,540 S1 = S2. 89 00:04:47,540 --> 00:04:50,430 Apa yang terjadi jika kita melakukan 90 00:04:50,430 --> 00:04:55,300 S1.age = 10? 91 00:04:56,340 --> 00:04:58,880 Apakah perubahan S2 sama sekali? 92 00:04:58,880 --> 00:05:02,800 Sekali lagi, memikirkan structs seperti bilangan bulat biasa. 93 00:05:02,800 --> 00:05:05,590 Jika kita menetapkan beberapa X int untuk beberapa Y int, 94 00:05:05,590 --> 00:05:08,970 seperti X = Y 95 00:05:08,970 --> 00:05:10,850 dan kemudian mengubah X, 96 00:05:10,850 --> 00:05:14,230 seperti di X + +, 97 00:05:14,230 --> 00:05:17,020 Y tidak berubah sama sekali? 98 00:05:17,020 --> 00:05:20,980 Y tidak berubah di sini, dan begitu juga tidak S2 di atas. 99 00:05:20,980 --> 00:05:24,120 S2.age masih 3. 100 00:05:24,120 --> 00:05:27,350 Tetapi perhatikan bahwa ketika menetapkan satu struct yang lain, 101 00:05:27,350 --> 00:05:30,300 semua pointer masih menunjuk ke hal yang sama, 102 00:05:30,300 --> 00:05:32,260 karena mereka hanya disalin. 103 00:05:32,260 --> 00:05:34,300 Jika Anda tidak ingin pointer untuk dibagikan, 104 00:05:34,300 --> 00:05:36,100 Anda harus secara manual menangani itu, 105 00:05:36,100 --> 00:05:39,780 mungkin dengan malicking satu blok memori untuk salah satu pointer untuk menunjuk ke 106 00:05:39,780 --> 00:05:42,120 dan menyalin data di atas. 107 00:05:42,120 --> 00:05:45,540 Ini mungkin mengganggu harus menulis mahasiswa struct di mana-mana. 108 00:05:45,540 --> 00:05:48,730 Menggunakan def jenis, yang bisa kita lakukan 109 00:05:51,630 --> 00:05:55,850 Jenis def 110 00:05:55,850 --> 00:05:58,830 struct 111 00:05:58,830 --> 00:06:01,270 dan kita akan menyebutnya siswa. 112 00:06:05,620 --> 00:06:08,360 Sekarang, kita dapat menggunakan mahasiswa di mana-mana 113 00:06:08,360 --> 00:06:11,090 yang kita gunakan untuk menggunakan struct mahasiswa. 114 00:06:11,090 --> 00:06:13,410 Ini def jenis merupakan struct anonim 115 00:06:13,410 --> 00:06:15,750 dan menyebutnya siswa. 116 00:06:15,750 --> 00:06:18,220 Tetapi jika kita juga menjaga identifier mahasiswa 117 00:06:18,220 --> 00:06:22,380 sebelah struct kata, seperti dalam mahasiswa struct typedef, 118 00:06:27,670 --> 00:06:31,590 kita bisa menggunakan kedua mahasiswa struct dan siswa bergantian sekarang. 119 00:06:31,590 --> 00:06:34,060 Mereka bahkan tidak memiliki nama yang sama. 120 00:06:34,060 --> 00:06:36,710 Kita bisa mengetik mahasiswa struct def ke Bob 121 00:06:36,710 --> 00:06:38,950 dan kemudian struct mahasiswa dan Bob 122 00:06:38,950 --> 00:06:41,270 akan jenis dipertukarkan. 123 00:06:41,270 --> 00:06:44,050 Terlepas dari def jenis, 124 00:06:44,050 --> 00:06:46,750 kita perlu identifier berikutnya untuk struct 125 00:06:46,750 --> 00:06:48,250 jika definisi struct 126 00:06:48,250 --> 00:06:50,450 adalah rekursif. 127 00:06:50,450 --> 00:06:52,620 Misalnya, 128 00:06:52,620 --> 00:06:56,140 Tipe def struct simpul 129 00:06:56,140 --> 00:07:01,200 dan itu akan didefinisikan sebagai val int 130 00:07:01,200 --> 00:07:05,420 dan itu akan memiliki pointer yang menunjuk ke node lain struct., 131 00:07:05,420 --> 00:07:09,490 seperti dalam simpul struct * berikutnya. 132 00:07:09,490 --> 00:07:13,670 Dan kemudian kita akan menyebutnya simpul. 133 00:07:15,490 --> 00:07:18,020 Struct ini rekursif, 134 00:07:18,020 --> 00:07:21,450 karena definisi node struct mengandung di dalamnya 135 00:07:21,450 --> 00:07:24,200 pointer ke node struct. 136 00:07:24,200 --> 00:07:27,740 Perhatikan bahwa kita harus mengatakan struct simpul * berikutnya 137 00:07:27,740 --> 00:07:30,690 dalam definisi node struct, 138 00:07:30,690 --> 00:07:33,620 sejak def jenis belum selesai untuk memungkinkan kita untuk menyederhanakan ini 139 00:07:33,620 --> 00:07:36,210 hanya * node berikutnya. 140 00:07:36,210 --> 00:07:39,260 Anda akan belajar lebih banyak tentang structs seperti ini 141 00:07:39,260 --> 00:07:41,750 ketika berhadapan dengan daftar link dan pohon. 142 00:07:41,750 --> 00:07:44,130 Bagaimana structs dalam suatu fungsi? 143 00:07:44,130 --> 00:07:46,800 Hal ini juga benar-benar berlaku. 144 00:07:46,800 --> 00:07:49,430 Kita bisa memiliki 145 00:07:49,430 --> 00:07:53,630 membatalkan func 146 00:07:53,630 --> 00:07:55,930 yang mengambil sebagai argumen, 147 00:07:55,930 --> 00:07:59,590 siswa s 148 00:07:59,590 --> 00:08:02,790 dan melakukan sesuatu dengan siswa itu. 149 00:08:05,270 --> 00:08:08,450 Dan kemudian kita bisa lulus sebagai struct mahasiswa seperti begitu. 150 00:08:08,450 --> 00:08:12,850 Func S1 dari sebelumnya. 151 00:08:12,850 --> 00:08:15,230 Struct berperilaku 152 00:08:15,230 --> 00:08:18,460 persis seperti integer akan ketika melewati ke fungsi. 153 00:08:18,460 --> 00:08:21,510 Func menerima salinan S1 154 00:08:21,510 --> 00:08:23,690 sehingga tidak dapat memodifikasi S1; 155 00:08:23,690 --> 00:08:27,110 melainkan, hanya salinannya yang disimpan dalam S. 156 00:08:27,110 --> 00:08:30,010 Jika Anda ingin fungsi untuk dapat memodifikasi S1, 157 00:08:30,010 --> 00:08:33,000 func akan perlu untuk mengambil * mahasiswa S, 158 00:08:33,000 --> 00:08:36,570 dan Anda akan harus melewati S1 berdasarkan alamat, seperti begitu. 159 00:08:37,549 --> 00:08:41,100 Mahasiswa * S, func & S1. 160 00:08:41,100 --> 00:08:44,760 Ada alasan lain untuk lewat alamat di sini. 161 00:08:44,760 --> 00:08:48,030 Bagaimana jika struct kami berisi 100 bidang? 162 00:08:48,030 --> 00:08:51,250 Setiap kali kami melewati siswa untuk func, 163 00:08:51,250 --> 00:08:55,770 program kami perlu untuk menyalin semua orang 100 bidang dalam S argumen fungsi ini, 164 00:08:55,770 --> 00:08:59,320 bahkan jika itu tidak pernah menggunakan sebagian besar dari mereka. 165 00:08:59,320 --> 00:09:02,700 Jadi bahkan jika fungsi tidak berencana untuk memodifikasi siswa, 166 00:09:02,700 --> 00:09:05,170 jika masih dapat berharga lewat alamat. 167 00:09:05,170 --> 00:09:08,990 Oke, bagaimana jika kita ingin membuat pointer ke struct? 168 00:09:08,990 --> 00:09:11,130 Kita bisa melakukan sesuatu seperti 169 00:09:11,130 --> 00:09:17,580 Mahasiswa S * 170 00:09:17,580 --> 00:09:20,980 sama dengan malloc 171 00:09:20,980 --> 00:09:26,600 ukuran mahasiswa. 172 00:09:30,450 --> 00:09:33,590 Perhatikan bahwa ukuran masih bekerja di sini. 173 00:09:33,590 --> 00:09:37,260 Jadi bagaimana kita sekarang mengakses anggota usia 174 00:09:37,260 --> 00:09:39,640 dari blok yang menunjuk ke S? 175 00:09:39,640 --> 00:09:42,300 Pertama-tama Anda mungkin berpikir untuk melakukan 176 00:09:42,300 --> 00:09:47,970 * S.age = 4, 177 00:09:47,970 --> 00:09:50,220 tapi ini tidak akan cukup bekerja. 178 00:09:50,220 --> 00:09:52,940 Karena ini benar-benar akan ditafsirkan sebagai 179 00:09:52,940 --> 00:09:57,740 * S.age dalam tanda kurung = 4, 180 00:09:57,740 --> 00:10:00,160 yang bahkan tidak akan mengkompilasi, 181 00:10:00,160 --> 00:10:03,600 karena S bukan struct atau lebih tepatnya pointer ke struct, 182 00:10:03,600 --> 00:10:06,270 dan sehingga titik tidak akan bekerja di sini. 183 00:10:06,270 --> 00:10:08,860 Kita bisa melakukan 184 00:10:08,860 --> 00:10:13,760 (* S). Usia 4 = 185 00:10:13,760 --> 00:10:16,790 tetapi kurung bisa mengganggu dan membingungkan. 186 00:10:16,790 --> 00:10:19,880 Untungnya, kita memiliki operator panah khusus 187 00:10:19,880 --> 00:10:22,350 yang terlihat seperti 188 00:10:22,350 --> 00:10:28,860 S-> umur = 4. 189 00:10:28,860 --> 00:10:31,600 Ini 2 cara referensi usia 190 00:10:31,600 --> 00:10:33,270 yang setara 191 00:10:33,270 --> 00:10:36,870 dan kita tidak benar-benar merasa perlu operator panah, 192 00:10:36,870 --> 00:10:39,300 tapi itu membuat hal-hal yang terlihat lebih bagus. 193 00:10:39,300 --> 00:10:43,050 Karena S adalah pointer ke beberapa blok memori yang berisi struct, 194 00:10:43,050 --> 00:10:47,820 Anda bisa memikirkan usia> S sebagai berikut panah pointer 195 00:10:47,820 --> 00:10:50,250 dan ambil anggota usia. 196 00:10:50,250 --> 00:10:53,750 Jadi mengapa harus kita pernah menggunakan struct? 197 00:10:53,750 --> 00:10:57,560 Ini jelas mungkin untuk lolos dengan hanya bilangan bulat primitif, 198 00:10:57,560 --> 00:10:59,050 karakter, pointer dan sejenisnya 199 00:10:59,050 --> 00:11:01,550 bahwa kita terbiasa; 200 00:11:01,550 --> 00:11:03,340 bukannya S1 dan S2 sebelumnya, 201 00:11:03,340 --> 00:11:06,290 kita bisa memiliki age1, age2, name1, dan name2 202 00:11:06,290 --> 00:11:09,120 semua pada variabel yang terpisah. 203 00:11:09,120 --> 00:11:11,390 Ini bagus dengan hanya 2 siswa, 204 00:11:11,390 --> 00:11:13,310 tapi bagaimana jika kita memiliki 10 dari mereka? 205 00:11:13,310 --> 00:11:15,540 Dan bagaimana jika bukan hanya 2 bidang, 206 00:11:15,540 --> 00:11:17,720 struct mahasiswa memiliki 100 bidang? 207 00:11:17,720 --> 00:11:21,240 IPK, kursus, warna rambut, jenis kelamin, dan sebagainya. 208 00:11:21,240 --> 00:11:25,790 Alih-alih hanya 10 structs, kita perlu 1.000 variabel yang terpisah. 209 00:11:25,790 --> 00:11:28,360 Juga, pertimbangkan fungsi 210 00:11:28,360 --> 00:11:32,270 yang mengambil struct bahwa dengan 100 bidang dengan argumen-satunya 211 00:11:32,270 --> 00:11:34,350 dan mencetak semua bidang. 212 00:11:34,350 --> 00:11:36,320 Jika kita tidak menggunakan struct, 213 00:11:36,320 --> 00:11:38,540 setiap kali kita memanggil fungsi itu, 214 00:11:38,540 --> 00:11:41,460 kita harus lulus di semua 100 variabel, 215 00:11:41,460 --> 00:11:44,430 dan jika kita memiliki 100 variabel untuk siswa 1, 216 00:11:44,430 --> 00:11:47,020 dan 100 variabel untuk siswa 2, 217 00:11:47,020 --> 00:11:50,540 kita harus yakin kita tidak sengaja melewati beberapa variabel dari siswa 1 218 00:11:50,540 --> 00:11:52,910 dan beberapa variabel dari siswa 2. 219 00:11:52,910 --> 00:11:55,710 Tidak mungkin untuk membuat kesalahan itu dengan struct, 220 00:11:55,710 --> 00:11:59,010 karena semua 100 variabel yang terkandung dalam satu paket. 221 00:11:59,010 --> 00:12:02,050 Hanya beberapa catatan akhir: 222 00:12:02,050 --> 00:12:04,870 Jika Anda sudah mengerti segala sesuatu sampai titik ini, besar. 223 00:12:04,870 --> 00:12:07,900 Sisanya video hanya demi kelengkapan '. 224 00:12:07,900 --> 00:12:11,010 Karena structs dapat menahan semua jenis pointer, 225 00:12:11,010 --> 00:12:14,220 mereka juga dapat menyelenggarakan fungsi pointer. 226 00:12:14,220 --> 00:12:17,040 Jika Anda terbiasa dengan pemrograman berorientasi objek, 227 00:12:17,040 --> 00:12:21,790 ini menyediakan cara untuk menggunakan struct untuk program dalam gaya berorientasi objek. 228 00:12:21,790 --> 00:12:24,500 Lebih lanjut mengenai pointer fungsi di lain waktu. 229 00:12:24,500 --> 00:12:27,760 Juga, kadang-kadang Anda mungkin memiliki 2 structs 230 00:12:27,760 --> 00:12:30,220 definisi yang tergantung pada satu sama lain. 231 00:12:30,220 --> 00:12:32,320 Misalnya, 232 00:12:32,320 --> 00:12:35,470 kita bisa memiliki struct A, 233 00:12:35,470 --> 00:12:38,580 yang didefinisikan sebagai 234 00:12:38,580 --> 00:12:41,910 pointer ke struct B, 235 00:12:41,910 --> 00:12:47,180 struct B * X, 236 00:12:47,180 --> 00:12:50,470 dan sekarang kita dapat memiliki B struct 237 00:12:53,890 --> 00:12:56,280 yang didefinisikan sebagai pointer 238 00:12:56,280 --> 00:12:59,180 ke A struct, 239 00:12:59,180 --> 00:13:03,640 struct A * Y. 240 00:13:07,230 --> 00:13:09,060 Tapi ini tidak dapat dikompilasi, 241 00:13:09,060 --> 00:13:14,110 karena struct B tidak ada pada waktu itu struct A sedang disusun. 242 00:13:14,110 --> 00:13:17,600 Dan jika kita bertukar struct A dan B struct, 243 00:13:17,600 --> 00:13:20,100 maka kita hanya akan dibiarkan dengan masalah yang sama; 244 00:13:20,100 --> 00:13:22,640 Kali ini, dengan struct A tidak ada. 245 00:13:22,640 --> 00:13:24,720 Untuk mengatasi hal ini, kita dapat menulis 246 00:13:24,720 --> 00:13:29,290 struct B; 247 00:13:29,290 --> 00:13:32,460 sebelum definisi struct A. 248 00:13:32,460 --> 00:13:35,590 Ini disebut deklarasi maju. 249 00:13:35,590 --> 00:13:38,590 Ini hanya memungkinkan compiler tahu bahwa 250 00:13:38,590 --> 00:13:42,040 struct B adalah jenis yang valid yang akan sepenuhnya ditentukan kemudian atau di tempat lain. 251 00:13:42,040 --> 00:13:45,980 Nama saya Rob Bowden, dan ini adalah CS50. 252 00:13:45,980 --> 00:13:48,980 [CS50.TV]