شروع دوره آزمایشی رایگان
Searching...
SoBrief
فارسی
EnglishEnglish
EspañolSpanish
简体中文Chinese
繁體中文Chinese (Traditional)
FrançaisFrench
DeutschGerman
日本語Japanese
PortuguêsPortuguese
ItalianoItalian
한국어Korean
РусскийRussian
NederlandsDutch
العربيةArabic
PolskiPolish
हिन्दीHindi
Tiếng ViệtVietnamese
SvenskaSwedish
ΕλληνικάGreek
TürkçeTurkish
ไทยThai
ČeštinaCzech
RomânăRomanian
MagyarHungarian
УкраїнськаUkrainian
Bahasa IndonesiaIndonesian
DanskDanish
SuomiFinnish
БългарскиBulgarian
עבריתHebrew
NorskNorwegian
HrvatskiCroatian
CatalàCatalan
SlovenčinaSlovak
LietuviųLithuanian
SlovenščinaSlovenian
СрпскиSerbian
EestiEstonian
LatviešuLatvian
فارسیPersian
മലയാളംMalayalam
தமிழ்Tamil
اردوUrdu
درک الگوریتم‌ها: راهنمای مصور برای برنامه‌نویسان و دیگر افراد کنجکاو

درک الگوریتم‌ها: راهنمای مصور برای برنامه‌نویسان و دیگر افراد کنجکاو

اثر آدیتیا بهارگاوا 2015 256 صفحه
4.41
۵٬۰۰۰+ امتیاز
گوش دادن
۳ روز دسترسی کامل رایگان
قفل گوش دادن و امکانات بیشتر را باز کنید!
ادامه

نکات کلیدی

۱. الگوریتم‌ها: پایه و اساس حل مسئله به‌صورت کارآمد

الگوریتم مجموعه‌ای از دستورالعمل‌ها برای انجام یک کار است.

تعریف الگوریتم. در اصل، الگوریتم یک روش یا مجموعه قوانین مشخص و تعریف‌شده است که برای حل یک مسئله خاص طراحی شده است. الگوریتم‌ها بلوک‌های بنیادی برنامه‌های کامپیوتری هستند که نحوه پردازش و دستکاری داده‌ها را برای رسیدن به نتیجه مطلوب تعیین می‌کنند. انتخاب الگوریتم تأثیر بسزایی بر کارایی و عملکرد برنامه دارد و به همین دلیل انتخاب الگوریتم مناسب یکی از جنبه‌های حیاتی توسعه نرم‌افزار به شمار می‌آید.

نمونه‌هایی از الگوریتم‌ها. الگوریتم‌ها محدود به دنیای علوم کامپیوتر نیستند و در زندگی روزمره نیز فراوان دیده می‌شوند. برای مثال:

  • دستور پخت کیک یک الگوریتم است.
  • مسیرهای رانندگی از یک مکان به مکان دیگر الگوریتم محسوب می‌شوند.
  • مراحل مونتاژ یک قطعه مبلمان نیز الگوریتم است.

اهمیت الگوریتم‌ها. درک الگوریتم‌ها برای برنامه‌نویسان بسیار حیاتی است، زیرا به آن‌ها امکان می‌دهد کدی کارآمد و مؤثر بنویسند. با انتخاب الگوریتم مناسب برای هر وظیفه، توسعه‌دهندگان می‌توانند عملکرد را بهینه کرده، مصرف منابع را کاهش دهند و تجربه کاربری را بهبود بخشند.

۲. جستجوی دودویی: شگفتی زمان لگاریتمی

در جستجوی دودویی، هر بار عدد وسط را حدس می‌زنید و نیمی از اعداد باقی‌مانده را حذف می‌کنید.

تعریف جستجوی دودویی. جستجوی دودویی الگوریتمی کارآمد برای یافتن مقدار مشخصی در یک فهرست مرتب است. این الگوریتم با تقسیم مکرر بازه جستجو به دو نیمه عمل می‌کند. اگر عنصر وسط برابر با مقدار هدف باشد، جستجو موفقیت‌آمیز است؛ در غیر این صورت، جستجو در نیمه چپ یا راست ادامه می‌یابد، بسته به اینکه مقدار هدف کمتر یا بیشتر از عنصر وسط باشد.

پیچیدگی زمانی لگاریتمی. مزیت اصلی جستجوی دودویی پیچیدگی زمانی لگاریتمی آن است که با نماد O(log n) نمایش داده می‌شود. این بدان معناست که تعداد گام‌های لازم برای یافتن مقدار هدف به صورت لگاریتمی با اندازه فهرست افزایش می‌یابد. برای مثال:

  • فهرستی با ۱۰۲۴ عنصر حداکثر به ۱۰ گام نیاز دارد.
  • فهرستی با ۱٬۰۴۸٬۵۷۶ عنصر حداکثر به ۲۰ گام نیاز دارد.

کاربردهای عملی. جستجوی دودویی در بسیاری از کاربردها که جستجوی کارآمد ضروری است، به کار می‌رود، از جمله:

  • جستجوی کلمه در فرهنگ لغت.
  • یافتن مخاطب در دفترچه تلفن.
  • جستجوی داده‌ها در شاخص پایگاه داده مرتب‌شده.

۳. آرایه‌ها در برابر لیست‌های پیوندی: انتخاب ساختار مناسب

در آرایه، تمام عناصر شما کنار هم ذخیره می‌شوند.

تعریف آرایه‌ها و لیست‌های پیوندی. آرایه‌ها و لیست‌های پیوندی دو ساختار داده‌ای بنیادی برای ذخیره مجموعه‌ای از عناصر هستند. آرایه‌ها عناصر را در مکان‌های حافظه متوالی ذخیره می‌کنند، در حالی که لیست‌های پیوندی عناصر را در مکان‌های غیرمتوالی نگهداری می‌کنند و هر عنصر به عنصر بعدی اشاره دارد. انتخاب بین آرایه و لیست پیوندی بستگی به نیازهای خاص برنامه دارد.

مزایای آرایه‌ها. آرایه‌ها امکان دسترسی سریع و تصادفی به عناصر را فراهم می‌کنند، به این معنی که هر عنصر را می‌توان مستقیماً با استفاده از اندیس آن در زمان O(1) دسترسی داشت. این ویژگی آرایه‌ها را برای برنامه‌هایی که نیاز به جستجوی مکرر عناصر دارند، مناسب می‌سازد.

مزایای لیست‌های پیوندی. لیست‌های پیوندی در درج و حذف عناصر، به‌ویژه در وسط لیست، عملکرد بسیار خوبی دارند. درج یا حذف یک عنصر در لیست پیوندی تنها نیازمند به‌روزرسانی اشاره‌گرهای عناصر مجاور است که می‌تواند در زمان O(1) انجام شود. این ویژگی لیست‌های پیوندی را برای برنامه‌هایی که نیاز به درج و حذف مکرر دارند، مناسب می‌کند.

۴. بازگشت (Recursion): زیبایی در خودارجاعی

بازگشت زمانی است که یک تابع خودش را فراخوانی می‌کند.

تعریف بازگشت. بازگشت یک تکنیک قدرتمند برنامه‌نویسی است که در آن یک تابع در تعریف خود، خودش را فراخوانی می‌کند. این امکان را می‌دهد که مسائل پیچیده به زیرمسائل کوچکتر و مشابه تقسیم شوند که به صورت بازگشتی حل می‌شوند تا زمانی که به یک حالت پایه برسیم.

حالت پایه و حالت بازگشتی. هر تابع بازگشتی باید دو بخش اساسی داشته باشد:

  • حالت پایه که مشخص می‌کند بازگشت کی باید متوقف شود.
  • حالت بازگشتی که تعریف می‌کند چگونه تابع باید خودش را با یک زیرمسئله کوچکتر فراخوانی کند.

پشته فراخوانی. توابع بازگشتی برای پیگیری وضعیت هر فراخوانی از پشته فراخوانی استفاده می‌کنند. هر بار که تابع خودش را فراخوانی می‌کند، یک فریم جدید به پشته اضافه می‌شود که متغیرها و زمینه اجرای تابع را ذخیره می‌کند. وقتی به حالت پایه رسیدیم، تابع بازمی‌گردد و فریم‌ها به ترتیب معکوس از پشته حذف می‌شوند.

۵. کوئیک‌سورت: تقسیم، تسخیر و مرتب‌سازی کارآمد

کوئیک‌سورت یک الگوریتم مرتب‌سازی است.

تعریف کوئیک‌سورت. کوئیک‌سورت الگوریتمی محبوب و کارآمد برای مرتب‌سازی است که از الگوی تقسیم و تسخیر بهره می‌برد. این الگوریتم با انتخاب یک عنصر «محور» از آرایه شروع می‌کند و عناصر دیگر را به دو زیرآرایه تقسیم می‌کند، بسته به اینکه کمتر یا بیشتر از محور باشند. سپس زیرآرایه‌ها به صورت بازگشتی مرتب می‌شوند و در نهایت زیرآرایه‌های مرتب شده با محور ترکیب می‌شوند تا آرایه نهایی مرتب حاصل شود.

تقسیم و تسخیر. کوئیک‌سورت نمونه‌ای از استراتژی تقسیم و تسخیر است که شامل شکستن مسئله به زیرمسائل کوچکتر مشابه، حل بازگشتی آن‌ها و سپس ترکیب راه‌حل‌ها برای حل مسئله اصلی است.

عملکرد متوسط. کوئیک‌سورت دارای پیچیدگی زمانی متوسط O(n log n) است که آن را به یکی از سریع‌ترین الگوریتم‌های مرتب‌سازی در عمل تبدیل می‌کند. با این حال، بدترین حالت آن O(n^2) است که ممکن است زمانی رخ دهد که محور به طور مکرر به‌صورت نامناسب انتخاب شود. برای کاهش این ریسک، معمولاً محور به صورت تصادفی انتخاب می‌شود.

۶. جدول‌های هش: قدرت جستجوی کلید-مقدار

جدول هش کلیدها را به مقادیر نگاشت می‌کند.

تعریف جدول‌های هش. جدول‌های هش ساختار داده‌ای قدرتمندی هستند که امکان ذخیره و بازیابی کارآمد جفت‌های کلید-مقدار را فراهم می‌کنند. آن‌ها با استفاده از یک تابع هش، هر کلید را به یک اندیس در آرایه نگاشت می‌کنند که مقدار متناظر در آنجا ذخیره می‌شود. این امکان را می‌دهد که عملیات جستجو، درج و حذف به طور متوسط در زمان ثابت O(1) انجام شود.

توابع هش. عملکرد جدول هش به کیفیت تابع هش بستگی زیادی دارد. یک تابع هش خوب باید کلیدها را به طور یکنواخت در آرایه توزیع کند تا برخوردها (زمانی که دو یا چند کلید به یک اندیس نگاشت می‌شوند) به حداقل برسد.

موارد استفاده. جدول‌های هش در بسیاری از کاربردها که جستجوی کارآمد کلید-مقدار ضروری است، به کار می‌روند، از جمله:

  • پیاده‌سازی فرهنگ لغت‌ها و جداول نماد.
  • کش کردن داده‌ها برای بازیابی سریع‌تر.
  • ایندکس‌گذاری پایگاه‌های داده برای جستجوی مؤثر.

۷. جستجوی سطح‌گسترده (BFS): پیمایش آسان شبکه‌ها

جستجوی سطح‌گسترده به شما می‌گوید آیا مسیری از A به B وجود دارد یا خیر.

تعریف جستجوی سطح‌گسترده. جستجوی سطح‌گسترده (BFS) الگوریتمی برای پیمایش گراف است که گراف را به صورت سطح به سطح کاوش می‌کند، شروع از یک گره مبدأ مشخص. این الگوریتم به طور سیستماتیک همه همسایگان گره مبدأ را بازدید می‌کند، سپس همسایگان آن‌ها و به همین ترتیب ادامه می‌دهد تا گره هدف پیدا شود یا کل گراف کاوش شود.

کوتاه‌ترین مسیر. BFS تضمین می‌کند که کوتاه‌ترین مسیر بین دو گره در گراف بدون وزن را پیدا کند، که کوتاه‌ترین مسیر به معنای مسیری با کمترین تعداد یال است.

صف‌ها. BFS از یک صف برای نگهداری گره‌هایی که باید بازدید شوند استفاده می‌کند. صف تضمین می‌کند که گره‌ها به ترتیب کشف‌شدن بازدید شوند که برای یافتن کوتاه‌ترین مسیر ضروری است.

۸. الگوریتم دیکسترا: یافتن کوتاه‌ترین مسیر وزن‌دار

الگوریتم دیکسترا برای محاسبه کوتاه‌ترین مسیر در گراف وزن‌دار استفاده می‌شود.

تعریف الگوریتم دیکسترا. الگوریتم دیکسترا الگوریتمی برای جستجوی گراف است که مسئله کوتاه‌ترین مسیر از یک مبدأ به همه گره‌های دیگر در گراف با وزن‌های غیرمنفی را حل می‌کند و در نتیجه یک درخت کوتاه‌ترین مسیر تولید می‌کند.

گراف‌های وزن‌دار. برخلاف جستجوی سطح‌گسترده، الگوریتم دیکسترا می‌تواند گراف‌های وزن‌دار را مدیریت کند، جایی که هر یال دارای یک مقدار عددی است که هزینه یا فاصله آن را نشان می‌دهد.

گراف‌های بدون حلقه جهت‌دار. الگوریتم دیکسترا تنها در گراف‌های بدون حلقه جهت‌دار (DAG) که گراف‌هایی بدون چرخه و با یال‌های جهت‌دار هستند، کاربرد دارد.

۹. الگوریتم‌های حریصانه: راه‌حل‌های سریع و تقریبی

الگوریتم‌های حریصانه بهینه‌سازی محلی انجام می‌دهند و امیدوارند به بهینه کلی برسند.

تعریف الگوریتم‌های حریصانه. الگوریتم‌های حریصانه رویکردی ساده و شهودی برای حل مسئله هستند که در هر مرحله بهترین انتخاب محلی را انجام می‌دهند، با این امید که به راه‌حل بهینه کلی دست یابند. این الگوریتم‌ها معمولاً زمانی به کار می‌روند که یافتن راه‌حل دقیق بسیار پرهزینه یا غیرممکن باشد.

الگوریتم‌های تقریبی. الگوریتم‌های حریصانه اغلب به عنوان الگوریتم‌های تقریبی استفاده می‌شوند که راه‌حلی نزدیک به بهینه ارائه می‌دهند اما ممکن است دقیقاً بهینه نباشند.

مسئله پوشش مجموعه. نمونه کلاسیکی از مسئله‌ای که الگوریتم‌های حریصانه در آن مفید هستند، مسئله پوشش مجموعه است که شامل یافتن کوچک‌ترین مجموعه‌ای از زیرمجموعه‌ها است که همه عناصر یک مجموعه داده شده را پوشش می‌دهند.

۱۰. برنامه‌نویسی پویا: بهینه‌سازی از طریق زیرمسائل

برنامه‌نویسی پویا زمانی مفید است که بخواهید چیزی را با محدودیت بهینه کنید.

تعریف برنامه‌نویسی پویا. برنامه‌نویسی پویا تکنیکی قدرتمند برای حل مسئله است که شامل شکستن مسئله پیچیده به زیرمسائل کوچکتر و همپوشان، حل هر زیرمسئله تنها یک بار و ذخیره نتایج در جدولی برای جلوگیری از محاسبه مجدد است. این رویکرد می‌تواند به طور قابل توجهی کارایی الگوریتم‌ها را برای مسائلی که ساختار بهینه و زیرمسائل همپوشان دارند، بهبود بخشد.

مسئله کوله‌پشتی. نمونه کلاسیکی از مسئله‌ای که با برنامه‌نویسی پویا حل می‌شود، مسئله کوله‌پشتی است که شامل انتخاب زیرمجموعه‌ای از اقلام با بیشترین ارزش است که در کوله‌پشتی با ظرفیت محدود جا می‌گیرند.

شبکه. هر راه‌حل برنامه‌نویسی پویا شامل یک شبکه است. مقادیر در خانه‌ها معمولاً همان چیزی است که می‌خواهید بهینه کنید. هر خانه یک زیرمسئله است، پس باید فکر کنید چگونه می‌توانید مسئله خود را به زیرمسائل تقسیم کنید.

۱۱. نزدیک‌ترین همسایگان (KNN): یادگیری از همسایگان

KNN برای طبقه‌بندی و رگرسیون استفاده می‌شود و شامل نگاه به k نزدیک‌ترین همسایگان است.

تعریف نزدیک‌ترین همسایگان. الگوریتم نزدیک‌ترین همسایگان (KNN) الگوریتمی ساده اما مؤثر در یادگیری ماشین است که برای هر دو وظیفه طبقه‌بندی و رگرسیون کاربرد دارد. این الگوریتم با یافتن k داده نزدیک‌ترین به نقطه پرس‌وجو کار می‌کند و سپس کلاس یا مقدار نقطه پرس‌وجو را بر اساس اکثریت کلاس یا میانگین مقدار همسایگان پیش‌بینی می‌کند.

طبقه‌بندی و رگرسیون. KNN می‌تواند برای طبقه‌بندی (دسته‌بندی داده‌ها به کلاس‌های مختلف) و رگرسیون (پیش‌بینی مقدار پیوسته) استفاده شود.

استخراج ویژگی. استخراج ویژگی فرآیند تبدیل داده‌های خام به مجموعه‌ای از ویژگی‌های عددی است که توسط الگوریتم KNN قابل استفاده باشند. انتخاب ویژگی‌ها برای عملکرد الگوریتم بسیار حیاتی است.

آخرین بروزرسانی:

Report Issue

خلاصه نقدها

4.41 از 5
میانگین ۵٬۰۰۰+ امتیاز از Goodreads و Amazon.

کتاب «درک الگوریتم‌ها: راهنمای مصور برای برنامه‌نویسان و دیگر افراد کنجکاو» به‌خاطر رویکرد ساده و تصویری خود در آموزش الگوریتم‌ها مورد تحسین فراوان قرار گرفته است. خوانندگان از سادگی بیان، تصاویر جذاب و توضیحات روشن آن استقبال می‌کنند که این کتاب را به معرفی بسیار مناسبی برای مبتدیان و یادآوری مفید برای برنامه‌نویسان باتجربه تبدیل کرده است. این اثر الگوریتم‌ها و ساختارهای داده‌ی پایه را پوشش می‌دهد و بسیاری آن را کتابی لذت‌بخش و آسان برای فهمیدن می‌دانند. برخی نقدها به نوسان سطح دشواری مطالب، وجود اشتباهات گاه‌به‌گاه و کم‌عمقی در برخی موضوعات اشاره دارند. به‌طور کلی، این کتاب به‌عنوان راهنمایی دوستانه و در دسترس برای الگوریتم‌ها به‌شدت توصیه می‌شود.

Your rating:
4.66
251 امتیاز
Want to read the full book?

سؤالات متداول

1. What’s "Grokking Algorithms" by Aditya Bhargava about?

  • Beginner-friendly algorithms guide: "Grokking Algorithms" is an illustrated introduction to algorithms, designed for programmers and curious readers who want to understand how algorithms work in practice.
  • Visual and example-driven: The book uses visuals, analogies, and real-world examples to explain complex concepts in a simple, engaging way.
  • Covers practical algorithms: It focuses on practical algorithms and data structures that are widely used, such as binary search, sorting, hash tables, and graph algorithms.
  • Step-by-step learning: Each chapter builds on the previous one, gradually introducing more advanced topics and reinforcing learning with exercises and code samples.

2. Why should I read "Grokking Algorithms" by Aditya Bhargava?

  • Accessible for beginners: The book is written for anyone with basic coding knowledge, making it ideal for self-taught programmers, bootcamp students, and those new to computer science.
  • Visual learning approach: If you’re a visual learner, the book’s illustrations and analogies make abstract concepts much easier to grasp.
  • Practical focus: The algorithms covered are chosen for their real-world usefulness, helping you solve common programming problems efficiently.
  • Foundation for further study: It provides a strong foundation for more advanced topics in algorithms, AI, databases, and machine learning.

3. What are the key takeaways from "Grokking Algorithms"?

  • Understanding algorithm efficiency: You’ll learn how to analyze and compare algorithms using Big O notation, focusing on how their performance scales.
  • Core data structures: The book explains arrays, linked lists, hash tables, and graphs, highlighting their strengths and weaknesses.
  • Problem-solving techniques: It introduces strategies like divide-and-conquer, recursion, greedy algorithms, and dynamic programming for tackling complex problems.
  • Real-world applications: Each algorithm is tied to practical use cases, such as search engines, recommendation systems, and network routing.

4. How does Aditya Bhargava explain Big O notation and algorithm performance in "Grokking Algorithms"?

  • Intuitive analogies: Bhargava uses relatable examples, like searching for a name in a phone book, to illustrate the difference between linear, logarithmic, and other time complexities.
  • Visual comparisons: The book includes charts and diagrams to help visualize how different algorithms scale as input size increases.
  • Focus on worst-case scenarios: Big O notation is explained as a way to describe the worst-case performance of an algorithm, helping you choose the right one for your needs.
  • Practical implications: Readers learn why understanding algorithm efficiency matters in real-world programming, such as optimizing for speed or memory.

5. What is the approach to teaching recursion in "Grokking Algorithms"?

  • Step-by-step breakdown: Recursion is introduced with simple, relatable problems, like searching for a key in nested boxes, to demystify the concept.
  • Base and recursive cases: The book emphasizes the importance of defining clear base and recursive cases to avoid infinite loops.
  • Call stack visualization: Bhargava explains how the call stack works during recursion, using diagrams and analogies like a stack of sticky notes.
  • Practical examples: Readers practice recursion with exercises like calculating factorials and summing lists, building confidence through repetition.

6. How does "Grokking Algorithms" explain and compare arrays, linked lists, and hash tables?

  • Memory and structure: The book uses analogies (like drawers and movie seats) to explain how arrays and linked lists store data in memory.
  • Strengths and weaknesses: Arrays are shown to be fast for random access but slow for insertions/deletions, while linked lists excel at inserts/deletes but are slow for random access.
  • Hash tables as hybrids: Hash tables are introduced as a powerful structure combining fast lookups with flexible storage, using hash functions to map keys to values.
  • Real-world use cases: Each data structure is tied to practical scenarios, such as implementing queues, phone books, and caches.

7. What are the main sorting and searching algorithms covered in "Grokking Algorithms," and how are they explained?

  • Binary search: Introduced early as a fast way to search sorted lists, with clear explanations of its O(log n) efficiency.
  • Selection sort: Used to teach basic sorting concepts and Big O analysis, showing why it’s less efficient (O(n²)) than more advanced algorithms.
  • Quicksort: Presented as a divide-and-conquer algorithm, with step-by-step partitioning and recursion, and a discussion of average vs. worst-case performance.
  • Comparison and context: The book compares these algorithms, helping readers understand when to use each and why efficiency matters.

8. How does "Grokking Algorithms" introduce graph algorithms like breadth-first search and Dijkstra’s algorithm?

  • Graphs as networks: The book models real-world problems (like finding the shortest route in a city) as graphs, making the concept tangible.
  • Breadth-first search (BFS): Explained as a way to find the shortest path in unweighted graphs, using queues and step-by-step exploration.
  • Dijkstra’s algorithm: Introduced for finding the shortest path in weighted graphs, with clear tables and diagrams to track costs and paths.
  • Practical applications: Examples include social networks, routing, and trading scenarios, showing the relevance of graph algorithms.

9. What is dynamic programming, and how is it taught in "Grokking Algorithms"?

  • Breaking down hard problems: Dynamic programming is introduced as a way to solve complex problems by breaking them into overlapping subproblems.
  • Grid-based solutions: The book uses grids to visualize subproblems, such as in the knapsack problem and longest common substring.
  • Step-by-step filling: Readers learn to fill in grids row by row or column by column, building up to the optimal solution.
  • Common pitfalls and tips: Bhargava addresses common questions, like handling dependencies and fractional items, and emphasizes when dynamic programming is appropriate.

10. How does "Grokking Algorithms" cover greedy algorithms and NP-complete problems?

  • Greedy strategy explained: The book defines greedy algorithms as those that make the locally optimal choice at each step, hoping for a global optimum.
  • Classic examples: Problems like classroom scheduling, the knapsack problem, and set covering are used to illustrate where greedy algorithms work and where they fall short.
  • Approximation algorithms: For NP-complete problems, the book advocates for approximation via greedy methods when exact solutions are impractical.
  • Recognizing NP-completeness: Readers are given tips to identify NP-complete problems and avoid wasting time seeking perfect solutions.

11. How does "Grokking Algorithms" introduce machine learning concepts like k-nearest neighbors (KNN)?

  • KNN for classification: The book explains KNN as a simple algorithm for classifying items based on the majority class of their nearest neighbors.
  • Feature extraction: Readers learn how to represent data (like fruit or users) as points in multi-dimensional space using relevant features.
  • Regression and recommendations: KNN is also shown as a tool for regression (predicting values) and building recommendation systems, such as for movies.
  • Limitations and improvements: The book discusses challenges like feature selection, normalization, and the use of cosine similarity for better results.

12. What are the best quotes from "Grokking Algorithms" by Aditya Bhargava, and what do they mean?

  • "Algorithm speed isn’t measured in seconds, but in growth of the number of operations." – Emphasizes the importance of understanding scalability over raw speed.
  • "Recursion may achieve a performance gain for your programmer." – Highlights that recursion can make code clearer and easier to reason about, even if not always faster.
  • "Greedy algorithms optimize locally, hoping to end up with a global optimum." – Sums up the core idea behind greedy strategies and their limitations.
  • "Dynamic programming is useful when you’re trying to optimize something given a constraint." – Captures when and why to use dynamic programming in problem-solving.
  • "I believe you learn best when you really enjoy learning—so have fun, and run the code samples!" – Encourages hands-on practice and enjoyment as keys to mastering algorithms.

درباره نویسنده

آدیتیا وای. بهارگا نویسنده‌ی کتاب «گروکینگ الگوریتم‌ها: راهنمای مصور برای برنامه‌نویسان و دیگر افراد کنجکاو» است. او به خاطر رویکرد منحصربه‌فردش در آموزش الگوریتم‌ها از طریق توضیحات تصویری و زبان ساده شناخته شده است. سبک نگارش بهارگا مفاهیم پیچیده را به گونه‌ای ارائه می‌دهد که برای مبتدیان و حتی کسانی که برنامه‌نویس نیستند نیز قابل فهم باشد. کتاب او به دلیل استفاده از تصاویر و مثال‌های واقعی برای توضیح مفاهیم الگوریتمی، محبوبیت زیادی پیدا کرده است. اگرچه اطلاعات شخصی زیادی درباره‌ی نویسنده در دسترس نیست، اما آثارش به خاطر توانایی در جذاب و کم‌هراس کردن الگوریتم‌ها برای خوانندگان مورد تحسین قرار گرفته است.

Follow
گوش دادن
Now playing
درک الگوریتم‌ها: راهنمای مصور برای برنامه‌نویسان و دیگر افراد کنجکاو
0:00
-0:00
Now playing
درک الگوریتم‌ها: راهنمای مصور برای برنامه‌نویسان و دیگر افراد کنجکاو
0:00
-0:00
1x
Queue
Home
Swipe
Library
Get App
Try Full Access for 3 Days
Listen, bookmark, and more
Compare Features Free Pro
📖 Read Summaries
Read unlimited summaries. Free users get 3 per month
🎧 Listen to Summaries
Listen to unlimited summaries in 40 languages
❤️ Unlimited Bookmarks
Free users are limited to 4
📜 Unlimited History
Free users are limited to 4
📥 Unlimited Downloads
Free users are limited to 1
Risk-Free Timeline
امروز: دسترسی فوری
گوش دادن به خلاصه کامل بیش از ۲۶,۰۰۰ کتاب. بیش از ۱۲,۰۰۰ ساعت محتوای صوتی!
روز دوم: یادآوری دوره آزمایشی
به شما اطلاع می‌دهیم که دوره آزمایشی‌تان به‌زودی پایان می‌یابد.
روز سوم: شروع اشتراک شما
مبلغ اشتراک در تاریخ Jun 13,
کسر می‌شود. هر زمان قبل از آن می‌توانید لغو کنید.
Consume 2.8× More Books
2.8× more books Listening Reading
Our users love us
600,000+ readers
Trustpilot Rating
TrustPilot
4.6 Excellent
This site is a total game-changer. I've been flying through book summaries like never before. Highly, highly recommend.
— Dave G
Worth my money and time, and really well made. I've never seen this quality of summaries on other websites. Very helpful!
— Em
Highly recommended!! Fantastic service. Perfect for those that want a little more than a teaser but not all the intricate details of a full audio book.
— Greg M
Save 62%
Yearly
$119.88 $44.99/year/yr
$3.75/mo
Monthly
$9.99/mo
Start a 3-Day Free Trial
3 days free, then $44.99/year. Cancel anytime.
Unlock a world of fiction & nonfiction books
26,000+ books for the price of 2 books
Read any book in 10 minutes
Discover new books like Tinder
Request any book if it's not summarized
Read more books than anyone you know
#1 app for book lovers
Lifelike & immersive summaries
30-day money-back guarantee
Download summaries in EPUBs or PDFs
Cancel anytime in a few clicks
Scanner
Find a barcode to scan

We have a special gift for you
Open
38% OFF
DISCOUNT FOR YOU
$79.99
$49.99/year
only $4.16 per month
Continue
2 taps to start, super easy to cancel
Settings
General
Widget
Loading...
We have a special gift for you
Open
38% OFF
DISCOUNT FOR YOU
$79.99
$49.99/year
only $4.16 per month
Continue
2 taps to start, super easy to cancel