در دنیای برنامهنویسی، انتخاب ساختار مناسب دادهها یکی از مهمترین تصمیمات است که میتواند تأثیر مستقیمی بر عملکرد، خوانایی و قابلیت نگهداری کد داشته باشد. در زبان برنامهنویسی سیشارپ (C#)، فضای نام System.Collections.Generic شامل مجموعهای از کلاسها و رابطها است که به توسعهدهندگان کمک میکنند تا دادهها را به شکلی کارآمد مدیریت کنند. یکی از این ساختارها، Sorted List یا لیست مرتبشده است که در مواقعی که نیاز به دسترسی سریع و مرتب به دادهها داریم، گزینهای ایدهآل محسوب میشود. در این مقاله به بررسی دقیق Sorted List در سیشارپ میپردازیم و نحوه استفاده، ویژگیها، مزایا و معایب آن را بررسی خواهیم کرد.
Sorted List چیست؟
کلاس SortedList<TKey, TValue> در سیشارپ یک کانتینر دادهای است که جفتهای کلید-مقدار (Key-Value Pairs) را ذخیره میکند و بهطور خودکار بر اساس کلیدها مرتبسازی میکند. این کلاس بخشی از فضای نام System.Collections.Generic است و از ویژگیهای نوعایمنی (type safety) و عملکرد بالا در زمان اجرا بهره میبرد. هر زمان که عنصری به Sorted List اضافه میشود، بهصورت خودکار در جای مناسب خود قرار میگیرد تا ترتیب صعودی کلیدها حفظ شود.
این ویژگی آن را به گزینهای مناسب برای سناریوهایی تبدیل میکند که نیاز به دسترسی مرتب و سریع به دادهها داریم، مانند پیادهسازی جداول تبدیل، نگهداری دادههای آماری مرتبشده یا ایجاد دیکشنریهایی که باید همواره مرتب باشند.
تفاوت Sorted List با سایر ساختارهای داده
مقایسه با Dictionary
یکی از سوالات رایج در مورد Sorted List، مقایسه آن با Dictionary<TKey, TValue> است. هر دو ساختار جفت کلید-مقدار را پشتیبانی میکنند، اما تفاوت اصلی در نحوه ذخیرهسازی و مرتبسازی است. دیکشنری برای دسترسی سریع به عناصر با استفاده از هش (Hash) طراحی شده و زمان دسترسی آن در حالت میانگین O(1) است، اما ترتیب عناصر تضمین نمیشود.
در مقابل، Sorted List عناصر را بر اساس کلید مرتب نگه میدارد و دسترسی به عناصر از طریق ایندکس یا کلید امکانپذیر است. البته این مرتبسازی خودکار باعث میشود که عملیات درج و حذف در بدترین حالت به زمان O(n) نیاز داشته باشد، زیرا ممکن است نیاز به جابجایی عناصر برای حفظ ترتیب وجود داشته باشد.
مقایسه با SortedDictionary
یک ساختار دیگر در .NET که شباهت زیادی به Sorted List دارد، SortedDictionary<TKey, TValue> است. این کلاس نیز جفتهای کلید-مقدار را به صورت مرتب نگه میدارد، اما از یک درخت سریال (Red-Black Tree) برای پیادهسازی استفاده میکند. در نتیجه، عملیات درج، حذف و جستجو در زمان O(log n) انجام میشود.
در حالی که Sorted List از یک آرایه داخلی استفاده میکند، SortedDictionary از ساختار درختی بهره میبرد. بنابراین، Sorted List برای دسترسی سریع به عناصر از طریق ایندکس و موقعیت مرتب مناسبتر است، در حالی که SortedDictionary برای عملیات پویای درج و حذف با حجم دادههای بالا کارآمدتر است.
نحوه استفاده از Sorted List در سیشارپ
ایجاد و مقداردهی اولیه
برای استفاده از Sorted List، ابتدا باید فضای نام System.Collections.Generic را با دستور using وارد کنید. سپس میتوانید یک نمونه از SortedList<TKey, TValue> ایجاد کنید. به عنوان مثال:
var sortedList = new SortedList<string, int>();
sortedList.Add(“Ali”, 25);
sortedList.Add(“Reza”, 30);
sortedList.Add(“Sara”, 22);
در این مثال، کلیدها از نوع رشته و مقادیر از نوع عدد صحیح هستند. پس از اضافه کردن عناصر، لیست بهطور خودکار بر اساس کلیدها (نامها) به صورت صعودی مرتب میشود.
دسترسی به عناصر
دسترسی به عناصر Sorted List میتواند از طریق کلید یا ایندکس انجام شود. برای دسترسی از طریق کلید:
int age = sortedList[“Ali”];
و برای دسترسی از طریق ایندکس:
var firstKey = sortedList.Keys[0];
var firstValue = sortedList.Values[0];
همچنین میتوان از حلقههای تکرار مانند foreach برای پیمایش تمام عناصر استفاده کرد:
foreach (var item in sortedList)
{
Console.WriteLine($”{item.Key}: {item.Value}”);
}
عملیات رایج در Sorted List
افزودن عناصر
برای افزودن عناصر از متد Add استفاده میشود. در صورتی که کلید تکراری باشد، استثنا (Exception) از نوع ArgumentException رخ میدهد. بنابراین، قبل از افزودن بهتر است وجود کلید را بررسی کنید:
if (!sortedList.ContainsKey(“Ali”))
{
sortedList.Add(“Ali”, 25);
}
حذف عناصر
حذف عناصر با استفاده از متد Remove انجام میشود که کلید را به عنوان ورودی میگیرد و در صورت موفقیت، مقدار true برمیگرداند:
bool removed = sortedList.Remove(“Reza”);
همچنین میتوان از RemoveAt برای حذف عنصر بر اساس ایندکس استفاده کرد:
sortedList.RemoveAt(0); // حذف اولین عنصر
جستجو و بررسی وجود کلید
برای بررسی وجود یک کلید از متد ContainsKey استفاده میشود که سریعتر از تلاش برای دسترسی به مقدار است. همچنین میتوان از TryGetValue برای جلوگیری از استثنا در صورت عدم وجود کلید استفاده کرد:
if (sortedList.TryGetValue(“Ali”, out int value))
{
Console.WriteLine($”Age: {value}”);
}
مزایای استفاده از Sorted List
مرتبسازی خودکار
یکی از بزرگترین مزایای Sorted List، مرتبسازی خودکار عناصر بر اساس کلید است. این ویژگی باعث میشود که در هر لحظه از برنامه، دادهها به صورت مرتب در دسترس باشند و نیازی به مرتبسازی دستی نباشد.
دسترسی سریع به ایندکس
برخلاف Dictionary، Sorted List اجازه دسترسی به عناصر از طریق ایندکس را میدهد. این ویژگی در سناریوهایی که نیاز به دسترسی به عنصر اول، آخر یا وسط لیست داریم، بسیار مفید است.
کارایی در دسترسی ترتیبی
در برنامههایی که به طور مداوم لیست را به صورت مرتب پیمایش میکنند، Sorted List عملکرد بهتری نسبت به SortedDictionary دارد، زیرا دادهها در حافظه به صورت پیوسته ذخیره میشوند و کش حافظه (Cache Locality) بهتری دارند.
معایب و محدودیتهای Sorted List
عملکرد پایین در درج و حذف
به دلیل استفاده از آرایه داخلی، هر بار که عنصری اضافه یا حذف میشود، ممکن است نیاز به جابجایی تمام عناصر بعدی وجود داشته باشد. این موضوع باعث میشود که عملیات درج و حذف در بدترین حالت به زمان O(n) نیاز داشته باشد که برای دادههای پویا و حجیم میتواند مشکلساز باشد.
عدم پشتیبانی از کلیدهای تکراری
SortedList اجازه وجود کلیدهای تکراری را نمیدهد. در صورت تلاش برای افزودن کلید تکراری، استثنا رخ میدهد. در صورت نیاز به کلیدهای تکراری، باید از ساختارهای دیگر مانند لیست جفتها یا پیادهسازی سفارشی استفاده کرد.
مصرف حافظه
هرچند Sorted List از دو آرایه داخلی (یکی برای کلیدها و یکی برای مقادیر) استفاده میکند، اما در مقایسه با Dictionary، ممکن است حافظه بیشتری مصرف کند، بهویژه اگر تعداد عناصر زیاد باشد و فضای آرایهها بیش از حد تخصیص یابد.
موارد استفاده عملی از Sorted List
نگهداری دادههای آماری مرتب
در برنامههایی که نیاز به نمایش دادههای آماری به ترتیب (مانند رتبهبندی کاربران، نمرات دانشآموزان یا فروش محصولات) دارند، Sorted List گزینه مناسبی است. با این ساختار میتوان به راحتی لیست را بهروزرسانی و بهصورت مرتب نمایش داد.
پیادهسازی جستجوی دودویی
از آنجا که عناصر در Sorted List مرتب هستند، میتوان از الگوریتم جستجوی دودویی برای یافتن سریع عناصر استفاده کرد. اگرچه این عملکرد به صورت مستقیم توسط کلاس ارائه نمیشود، اما با استفاده از ایندکس و ترتیب، پیادهسازی آن آسان است.
استفاده در محیطهای گزارشگیری
در سیستمهای گزارشگیری که خروجی باید به صورت الفبایی یا عددی مرتب باشد، استفاده از Sorted List میتواند به کاهش کد مرتبسازی دستی و افزایش خوانایی کد کمک کند.
جمعبندی و نتیجهگیری
کلاس SortedList<TKey, TValue> در سیشارپ ابزار قدرتمندی برای مدیریت جفتهای کلید-مقدار به صورت مرتب است. این ساختار با ترکیب مزایای دیکشنری و لیست مرتب، گزینهای مناسب برای سناریوهایی است که نیاز به دسترسی سریع و مرتب به دادهها داریم. با این حال، باید به معایب آن مانند عملکرد پایین در درج و حذف و عدم پشتیبانی از کلیدهای تکراری توجه داشت.
انتخاب بین Sorted List، Dictionary و SortedDictionary به نیازهای خاص پروژه بستگی دارد. اگر دادهها نسبتاً ثابت هستند و نیاز به پیمایش مرتب دارید، Sorted List گزینه بهتری است. اما اگر عملیات درج و حذف پویا و متعدد است، SortedDictionary ممکن است عملکرد بهتری داشته باشد.
در نهایت، درک عمیق از ویژگیهای هر ساختار داده به شما کمک میکند تا تصمیمهای هوشمندانهتری در طراحی برنامههای خود بگیرید و از قابلیتهای سیشارپ به بهترین شکل استفاده کنید.

آخرین دیدگاه ها