فهرست سرفصل‌های ++C
خانه (HOME) مقدمه (Intro) شروع کار (Get Started) نحوه نگارش (Syntax) دستورات (Statements) چاپ متن (Print Text) چاپ اعداد (Print Numbers) خط های جدید (New Lines) کامنت ها (Comments) اعلان متغیرها (Declare Variables) متغیرهای متعدد (Multiple Variables) شناسه ها (Identifiers) ثابت ها (Constants) نمونه های دنیای واقعی (Real-Life Examples) ورودی کاربر (User Input) انواع داده پایه (Basic Data Types) اعداد (Numbers) بولی ها (Booleans) کاراکترها (Characters) رشته ها (Strings) کلیدواژه auto (The auto Keyword) نمونه عملی (Real-Life Example) عملگرها (Operators) حسابی (Arithmetic) انتساب (Assignment) مقایسه (Comparison) منطقی (Logical) اولویت (Precedence) مقدمه رشته ها (Strings Intro) به هم چسباندن (Concatenation) اعداد و رشته ها (Numbers and Strings) طول رشته (String Length) دسترسی به رشته ها (Access Strings) کاراکترهای ویژه (Special Characters) ورودی کاربرِ رشته ها (User Input Strings) حذف فضای نام (Omitting Namespace) رشته های سبک C (C-Style Strings) ریاضی (Math) مقادیر بولی (Boolean Values) عبارات بولی (Boolean Expressions) نمونه عملی (Real-Life Example) شرط ها If...Else (If...Else) else (else) else if (else if) اگر کوتاه (Short hand if..else) تودر تو (Nested if) عملگرهای منطقی (Logical Operators) سوییچ (Switch) حلقه While (While Loop) حلقه Do/While (Do/While Loop) نمونه های عملی (Real-Life Examples) حلقه For (For Loop) حلقه های تو در تو (Nested Loops) حلقه foreach (The foreach Loop) نمونه های عملی (Real-Life Examples) شکستن/ادامه (Break/Continue) آرایه ها (Arrays) آرایه ها و حلقه ها (Arrays and Loops) حذف اندازه آرایه (Omit Array Size) گرفتن اندازه آرایه (Get Array Size) نمونه عملی (Real-Life Example) آرایه های چندبعدی (Multidimensional Arrays) ساختارها (Structures) گزاره شمار/Enums (Enums) ارجاع ها (References) ساخت ارجاع (Create References) آدرس حافظه (Memory Address) اشاره گرها (Pointers) ایجاد اشاره گر (Create Pointers) ارجاع زدایی (Dereferencing) تغییر اشاره گرها (Modify Pointers) مدیریت حافظه (Memory Management) new و delete (new and delete) توابع (Functions) پارامترهای تابع (Function Parameters) پارامتر/آرگومان ها (Parameters/Arguments) پارامتر پیش فرض (Default Parameter) پارامترهای متعدد (Multiple Parameters) مقادیر بازگشتی (Return Values) ارسال با ارجاع (Pass By Reference) ارسال آرایه ها (Pass Arrays) ارسال ساختارها (Pass Structures) نمونه عملی (Real-Life Example) بارگذاری هم نام (Function Overloading) بازگشت/بازگشتی (Recursion) لامبدا (Lambda) برنامه نویسی شی گرا OOP (OOP) کلاس ها/اشیاء (Classes/Objects) متدهای کلاس (Class Methods) سازنده ها (Constructors) سازنده سربار (Constructor Overloading) مشخصه های دسترسی (Access Specifiers) کپسوله سازی (Encapsulation) توابع دوست (Friend Functions) ارث بری (Inheritance) ارث بری چندسطحی (Multilevel Inheritance) ارث بری چندگانه (Multiple Inheritance) مشخصه های دسترسی در ارث بری (Access Specifiers) چندریختی (Polymorphism) توابع مجازی (Virtual Functions) قالب ها (Templates) فایل ها (Files) تاریخ (Date) اشکال زدایی (Debugging) استثناها (Exceptions) اعتبارسنجی ورودی (Input Validation) ساختارهای داده و STL (Data Structures & STL) وکتورها (Vectors) لیست (List) پشته ها (Stacks) صف ها (Queues) دک (Deque) مجموعه ها (Sets) نقشه ها (Maps) الگوریتم ها (Algorithms) فضای نام ها (Namespaces) پروژه ها (Projects) جمع دو عدد (Add Two Numbers) اعداد تصادفی (Random Numbers)
++C

++C — دک (Deque)

آخرین بروزرسانی: 1404/08/04

دک (Deque)

دک در C++ یعنی صفِ دوطرفه. یعنی از دو سر کار می کند. می شود از جلو و عقب اضافه یا حذف کرد. همچنین با ایندکس هم دسترسی داری.

دک در C++ چیست؟

دک مخفف Double-Ended Queue است. یعنی «صف با دو سر». برخلاف صف معمولی، افزودن و حذف از هر دو طرف ممکن است. همچنین، با ایندکس عناصر را می خوانی.

#include <deque>

مشاهده در ادیتور

ساخت دک

با کلیدواژه deque و نوع داخل <> یک دک بساز.

std::deque<std::string> cars;

مشاهده در ادیتور

می توانی هنگام تعریف، با {} مقداردهی کنی. سپس با حلقه چاپ کن.

std::deque<std::string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
for (std::string car : cars) {
  std::cout << car << "\n";
}

مشاهده در ادیتور

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

مثل آرایه، از [] استفاده کن. همچنین .front() و .back() هم هست.

std::deque<std::string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
std::cout << cars[0];
std::cout << cars[1];

مشاهده در ادیتور

std::deque<std::string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
std::cout << cars.front();
std::cout << cars.back();

مشاهده در ادیتور

تابع at برای دسترسی امن

تابع .at() اگر بیرونِ محدوده باشی، خطا می دهد. بنابراین امن تر است.

std::deque<std::string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
std::cout << cars.at(1);
std::cout << cars.at(2);

مشاهده در ادیتور

std::deque<std::string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
std::cout << cars.at(6);

مشاهده در ادیتور

تغییر مقدار عنصر

با ایندکس مقدار عوض می شود. یا امن تر، با .at() انجام بده.

std::deque<std::string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
cars[0] = "Opel";
std::cout << cars[0];

مشاهده در ادیتور

std::deque<std::string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
cars.at(0) = "Opel";
std::cout << cars.at(0);

مشاهده در ادیتور

افزودن و حذف از هر دو طرف

برای افزودن، از .push_front() و .push_back() استفاده کن.

std::deque<std::string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
cars.push_front("Tesla");
cars.push_back("VW");

مشاهده در ادیتور

برای حذف، از .pop_front() و .pop_back() کمک بگیر.

std::deque<std::string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
cars.pop_front();
cars.pop_back();

مشاهده در ادیتور

اندازه و خالی بودن

با .size() تعداد عناصر را بگیر. با .empty() خالی بودن را بسنج.

std::deque<std::string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
std::cout << cars.size();

مشاهده در ادیتور

std::deque<std::string> a;
std::cout << a.empty();

مشاهده در ادیتور

std::deque<std::string> b = {"Volvo", "BMW", "Ford", "Mazda"};
std::cout << b.empty();

مشاهده در ادیتور

حلقه روی دک

می توانی با for و ایندکس Loop بزنی. یا از for-each استفاده کن.

std::deque<std::string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
for (int i = 0; i < cars.size(); i++) {
  std::cout << cars[i] << "\n";
}

مشاهده در ادیتور

std::deque<std::string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
for (std::string car : cars) {
  std::cout << car << "\n";
}

مشاهده در ادیتور

تمرین سه مرحله ای

  1. یک دک رشته ای بساز.
  2. با push_front و push_back چند مقدار بده.
  3. با pop_front یکی حذف کن و front را چاپ کن.

نکته: اگر فقط انتها مهم است، وکتورها راحت ترند. اگر فقط FIFO می خواهی، صف ها بهترند. توضیح کاملِ دک در C++ همین صفحه است.

جمع بندی سریع

  • افزودن و حذف از هر دو طرف.
  • دسترسی با ایندکس هم ممکن است.
  • .at() امن تر از [] است.
  • .size() تعداد را می دهد و .empty() وضعیت را.