فهرست سرفصل‌های Java
خونه (HOME) مقدمه (Intro) شروع کار (Get Started) نحوه نگارش (Syntax) دستورات (Statements) خروجی (Output) چاپ اعداد (Print Numbers) کامنت ها (Comments) متغیرها (Variables) چاپ متغیرها (Print Variables) چندین متغیر (Multiple Variables) شناسه ها (Identifiers) ثابت ها / فاینال (Constants (Final)) نمونه های واقعی (Real-Life Examples) انواع داده (Data Types) اعداد (Numbers) بولی ها (Booleans) کاراکترها (Characters) نمونه واقعی (Real-Life Example) غیراولیّه ها (Non-primitive Types) کلیدواژه var (The var Keyword) تبدیل نوع (Type Casting) حسابی (Arithmetic) انتساب (Assignment) مقایسه (Comparison) منطقی (Logical) اولویت (Precedence) رشته ها (Strings) به هم چسباندن (Concatenation) اعداد و رشته ها (Numbers and Strings) کاراکترهای ویژه (Special Characters) بولی ها (Booleans) شرط ها If...Else (If...Else) else else if حالت کوتاه if...else (Short Hand If...Else) عملگرهای منطقی (Logical Operators) نمونه های واقعی (Real-Life Examples) سوییچ (Switch) حلقه while (While Loop) نمونه های واقعی while (Real-Life Examples) حلقه for (For Loop) حلقه های تو در تو (Nested Loops) حلقه foreach (For-Each Loop) نمونه های واقعی for (Real-Life Examples) شکستن/ادامه (Break/Continue) آرایه ها (Arrays) حلقه روی آرایه (Loop Through an Array) نمونه های واقعی آرایه (Real-Life Examples) آرایه های چندبعدی (Multidimensional Arrays) متدها (Methods) پارامترهای متد (Method Parameters) مقادیر بازگشتی (Return Values) سربارگذاری متد (Method Overloading) اسکوپ (Scope) بازگشتی (Recursion) شی ءگرایی (OOP) کلاس ها/اشیاء (Classes/Objects) خصوصیات کلاس (Class Attributes) متدهای کلاس (Class Methods) سازنده ها (Constructors) this (this Keyword) تعدیل کننده ها (Modifiers) تعدیل کننده های دسترسی (Access Modifiers) تعدیل کننده های غیردسترسی (Non-Access Modifiers) کپسوله سازی (Encapsulation) پکیج ها / API (Packages / API) ارث بری (Inheritance) چندریختی (Polymorphism) super (super Keyword) کلاس های درونی (Inner Classes) انتزاع (Abstraction) اینترفیس (Interface) ناشناس (Anonymous) enumها (Enum) سازنده در enum (Enum Constructor) ورودی کاربر (User Input) تاریخ (Date) خطاها (Errors) دیباگ (Debugging) استثناها (Exceptions) چند استثنا (Multiple Exceptions) try-with-resources کار با فایل (Files) ایجاد فایل (Create Files) نوشتن فایل (Write Files) خواندن فایل (Read Files) حذف فایل (Delete Files) جریان های I/O (I/O Streams) FileInputStream FileOutputStream BufferedReader BufferedWriter ساختار داده (Data Structures) کالکشن ها (Collections) لیست (List) آرِیلیست (ArrayList) لینکدلیست (LinkedList) مرتب سازی لیست (List Sorting) مجموعه (Set) هش ست (HashSet) تری ست (TreeSet) لینکدهش ست (LinkedHashSet) نقشه (Map) هش مپ (HashMap) تری مپ (TreeMap) لینکدهش مپ (LinkedHashMap) ایتراتور (Iterator) الگوریتم ها (Algorithms) کلاس های بسته بندی (Wrapper Classes) جنریک ها (Generics) انوتیشن ها (Annotations) عبارات باقاعده (RegEx) رشته ها (Threads) لامبدا (Lambda) مرتب سازی پیشرفته (Advanced Sorting) پروژه ها (Projects) چگونه ها (How Tos) جمع دو عدد (Add Two Numbers) جابجایی دو متغیر (Swap Two Variables) زوج یا فرد (Even or Odd Number) برعکس کردن عدد (Reverse a Number) مثبت یا منفی (Positive or Negative) ریشه مربع (Square Root) مساحت مستطیل (Area of Rectangle) درجه سلسیوس به فارنهایت (Celsius to Fahrenheit) جمع ارقام (Sum of Digits) عدد آرمسترانگ (Check Armstrong Num) عدد تصادفی (Random Number) شمارش کلمات (Count Words) شمارش حروف صدادار (Count Vowels in a String) حذف حروف صدادار (Remove Vowels) شمارش ارقام در رشته (Count Digits in a String) برعکس کردن رشته (Reverse a String) بررسی پالیندروم (Palindrome Check) بررسی اَناگرام (Check Anagram) تبدیل رشته به آرایه (Convert String to Array) حذف فاصله های خالی (Remove Whitespace) شمارش فراوانی کاراکتر (Count Character Frequency) جمع عناصر آرایه (Sum of Array Elements) میانگین آرایه (Find Array Average) مرتب سازی آرایه (Sort an Array) کوچک ترین عنصر (Find Smallest Element) بزرگ ترین عنصر (Find Largest Element) ادغام دو آرایه (Merge Two Arrays) حذف تکراری ها (Remove Duplicates) پیدا کردن مقادیر تکراری (Find Duplicates) درهم زدن آرایه (Shuffle an Array) فاکتوریل (Factorial of a Number) دنباله فیبوناچی (Fibonacci Sequence) ب.م.م (Find GCD) تشخیص اول بودن (Check Prime Number) حلقه روی ArrayList (ArrayList Loop) حلقه روی HashMap (HashMap Loop) حلقه روی Enum (Loop Through an Enum) مرجع جاوا (Reference) کلیدواژه ها (Keywords) assert abstract boolean break byte case catch char class continue default do double else enum exports extends final finally float for if implements import instanceof int interface long module native new package private protected public return requires short static super switch synchronized this throw throws transient try var void volatile while متدهای رشته (String Methods) charAt() codePointAt() codePointBefore() codePointCount() compareTo() compareToIgnoreCase() concat() concat() contentEquals() contentEquals() endsWith() equals() equalsIgnoreCase() format() getBytes() getChars() hashCode() indexOf() isEmpty() join() lastIndexOf() length() matches() matches() regionMatches() replace() replaceAll() replaceFirst() split() subSequence() substring() toCharArray() toLowerCase() toString() toUpperCase() trim() valueOf() متدهای ریاضی (Math Methods) abs() acos() addExact() atan2() cbrt() ceil() copySign() cos() cosh() exp() expm1() getExponent() hypot() incrementExact() log() log10() log1p() max() min() multiplyExact() negateExact() nextAfter() nextDown() nextUp() pow() random() rint() round() scalb() signum() sin() sinh() sqrt() subtractExact() tan() tanh() toDegrees() toIntExact() toRadians() ulp() روش های خروجی (Java Output Methods) print() printf() println() روش های آرایه ها (Java Arrays Methods) compare() equals() sort() fill() length روش های ArrayList (Java ArrayList Methods) add() addAll() clear() clone() contains contains contains contains contains contains iterator() lastIndexOf() listIterator() remove() removeAll() removeIf() replaceAll() retainAll() retainAll() set() size() sort() spliterator() toArray() trimToSize() trimToSize() روش های LinkedList (Java LinkedList Methods) add() add() addAll() clear() clone() contains forEach() get() getFirst() getLast() indexOf() isEmpty() iterator() lastIndexOf() lastIndexOf() listIterator() remove()
Java

Java — تری ست (TreeSet)

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

تری ست (TreeSet)

«تری ست (TreeSet)» مجموعه ای از اعضای یکتا است که همیشه مرتب می ماند. مثل لیست نمره ها که از کوچکتر به بزرگتر چیده می شود. این کلاس در بسته java.util است و «رابط (Set)» را پیاده سازی می کند.

ساخت TreeSet

«رابط (Interface)» یعنی قرارداد رفتار. TreeSet طبق قرارداد Set کار می کند و مرتب می سازد.

import java.util.TreeSet; // Import the TreeSet class

TreeSet<String> cars = new TreeSet<>();

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

افزودن عضو؛ مرتب سازی خودکار

با «add()» عضو اضافه کن. تکراری ها فقط یک بار می مانند. خروجی همیشه مرتب است.

import java.util.TreeSet;

public class Main {
  public static void main(String[] args) {
    TreeSet<String> cars = new TreeSet<>();
    cars.add("Volvo");
    cars.add("BMW");
    cars.add("Ford");
    cars.add("BMW"); // Duplicate
    cars.add("Mazda");
    System.out.println(cars);
  }
}

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

نکته: عناصر به صورت خودکار مرتب می شوند. مقدار تکراری فقط یک بار دیده می شود.

بررسی وجود عضو

برای پرسیدن «هست یا نه؟»، از «contains()» استفاده کن. مثل جست وجوی نام در لیست.

cars.contains("Mazda");

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

حذف یک عضو و پاک سازی کامل

برای حذف از «remove()» و برای خالی کردن از «clear()» استفاده کن.

cars.remove("Volvo");

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

cars.clear();

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

تعداد اعضا

با «size()» تعداد اعضای یکتا را می بینی. تکراری ها شمارش نمی شوند.

cars.size();

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

حلقه foreach روی TreeSet

با for-each از روی عناصر مرتب عبور کن. خروجی ترتیب طبیعی دارد.

TreeSet<String> cars = new TreeSet<>();
// add elements...
for (String i : cars) {
  System.out.println(i);
}

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

TreeSet با اعداد

TreeSet با عددها هم کار می کند. اعداد را از کوچک به بزرگ می چیند.

import java.util.TreeSet;

public class Main {
  public static void main(String[] args) {
    TreeSet<Integer> numbers = new TreeSet<>();
    numbers.add(40);
    numbers.add(10);
    numbers.add(30);
    numbers.add(20);
    for (int n : numbers) {
      System.out.println(n);
    }
  }
}

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

مقایسه HashSet و TreeSet

نکته: اگر سرعت مهم است، از HashSet استفاده کن. اگر مرتب بودن مهم است، TreeSet بهتر است.

کلیدواژه var در تری ست جاوا

از جاوا 10 «var» نوع را حدس می زند. اما برای شفافیت، خیلی ها نوع کامل را می نویسند.

// Without var
TreeSet<String> cars = new TreeSet<String>();

// With var
var cars = new TreeSet<String>();

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

اعلان با Set و نمونه TreeSet

گاهی متغیر را Set اعلام می کنند اما نمونه TreeSet می سازند. این روش انعطاف آینده را بیشتر می کند.

import java.util.Set;
import java.util.TreeSet;

Set<String> cars = new TreeSet<>();

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

گام های تمرینی

  1. یک TreeSet بساز و چند نام اضافه کن.
  2. یک نام تکراری بفرست و نتیجه را ببین.
  3. با contains و size وضعیت را بررسی کن.

نکته: برای آشنایی با مجموعه ها، صفحه مجموعه (Set) را هم ببین. اگر ترتیب ورود مهم است، LinkedHashSet را بررسی کن.

جمع بندی سریع

  • TreeSet یکتا و همیشه مرتب است.
  • تکراری ها حذف می شوند.
  • contains و remove پرکاربرد هستند.
  • اعداد و رشته ها را طبیعی مرتب می کند.
  • برای سرعت تنها، HashSet مناسب تر است.