عملگر شرطی به ارزیابی یک شرط و انجام عمل خاصی بر اساس نتیجه آن اشاره دارد. این عملگر معمولاً در تصمیمگیریها و کنترل جریان برنامه استفاده میشود.
جدول هش (Hash Table) یک ساختار دادهای است که برای ذخیرهسازی دادهها به شکلی کارآمد و سریع طراحی شده است. این ساختار داده با استفاده از یک تابع هش، که دادهها را به اندیسهای خاصی نگاشت میکند، به سرعت به جستجو، اضافه کردن، و حذف دادهها پرداخته و زمان دسترسی را کاهش میدهد.
در جدول هش، هر داده به یک کلید (Key) و یک مقدار (Value) متصل است. کلید توسط تابع هش به یک موقعیت خاص (یا ایندکس) در آرایه اشاره میکند. سپس دادههای مرتبط در آن موقعیت ذخیره میشوند. یکی از ویژگیهای جدول هش این است که امکان دسترسی به دادهها با زمان ثابت O(1) فراهم میشود، به شرط آنکه تابع هش به خوبی طراحی شده باشد و برخورد (collision) نداشته باشیم.
در صورتی که دو کلید با استفاده از تابع هش به یک موقعیت مشابه نگاشت شوند، یک برخورد رخ میدهد. برای حل این مشکل، از روشهایی مانند زنجیرهای (Chaining) و بازپرسازی خطی (Linear Probing) استفاده میشود.
در اینجا یک پیادهسازی ساده از جدول هش در زبان Python آورده شده است:
class HashTable:
def __init__(self, size):
self.size = size
self.table = [None] * size
def hash_function(self, key):
return hash(key) % self.size
def insert(self, key, value):
index = self.hash_function(key)
self.table[index] = value
def search(self, key):
index = self.hash_function(key)
return self.table[index]
def delete(self, key):
index = self.hash_function(key)
self.table[index] = None در این کد، جدول هش به صورت یک آرایه از اندازه مشخص شده ساخته میشود. تابع hash_function از تابع hash() برای محاسبه ایندکس استفاده میکند. سپس، دادهها از طریق متدهای insert، search و delete در جدول ذخیره، جستجو و حذف میشوند.
در زبان Java، پیادهسازی جدول هش به شکل زیر است:
import java.util.LinkedList; public class HashTable {
private LinkedList<Entry>[] table;
private int size;
public HashTable(int size) {
this.size = size;
table = new LinkedList[size];
}
private int hashFunction(String key) {
return key.hashCode() % size;
}
public void insert(String key, String value) {
int index = hashFunction(key);
if (table[index] == null) {
table[index] = new LinkedList<>();
}
table[index].add(new Entry(key, value));
}
public String search(String key) {
int index = hashFunction(key);
if (table[index] != null) {
for (Entry entry : table[index]) {
if (entry.key.equals(key)) {
return entry.value;
}
}
}
return null;
}
public void delete(String key) {
int index = hashFunction(key);
if (table[index] != null) {
table[index].removeIf(entry -> entry.key.equals(key));
}
}
private class Entry {
String key;
String value;
Entry(String key, String value) {
this.key = key;
this.value = value;
}
} } در اینجا، از یک آرایه از لیستهای پیوندی (LinkedList) برای حل برخوردها استفاده شده است. هر ایندکس در آرایه به یک لیست پیوندی اشاره دارد که چندین عنصر ممکن است در آن ذخیره شوند، به این ترتیب با برخوردها به درستی مقابله میشود.
یکی از مزایای بزرگ جدول هش، زمان جستجو و دسترسی سریع آن است. با این حال، کارایی آن به طراحی تابع هش بستگی دارد. اگر تابع هش به درستی طراحی نشده باشد، تعداد برخوردها افزایش یافته و کارایی کاهش مییابد. همچنین، در صورتی که جدول هش بیش از حد پر شود، ممکن است نیاز به بازسازی جدول و افزایش اندازه آن باشد.
برای اطلاعات بیشتر، میتوانید از سایت saeidsafaei.ir و اسلایدهای محمد سعید صفایی بهرهبرداری کنید.
در این مبحث، به مقدمهای بر برنامهنویسی پرداخته و مفاهیم اساسی آن شامل تعریف برنامهنویسی، اهمیت برنامهنویسی، روشهای ترجمه کد، انواع زبانهای برنامهنویسی، و مهارتها و محیطهای برنامهنویسی بررسی میشود. هدف این جلسه، آشنایی با اصول پایهای برنامهنویسی و درک نحوه انتخاب زبان و محیط مناسب برای نوشتن برنامههای کاربردی است.
عملگر شرطی به ارزیابی یک شرط و انجام عمل خاصی بر اساس نتیجه آن اشاره دارد. این عملگر معمولاً در تصمیمگیریها و کنترل جریان برنامه استفاده میشود.
یکپارچگی دادهها به تضمین صحت، دقت و اعتبار دادهها در سراسر سیستمهای مختلف اطلاق میشود.
جستجو به معنای پیدا کردن دادهها در یک ساختار دادهای خاص مانند آرایهها یا لیستها است.
حافظه اولیه، که معمولاً شامل RAM و حافظه کش است، برای ذخیرهسازی دادههای در حال پردازش استفاده میشود.
فرآیند تبدیل اطلاعات به کدی غیرقابل فهم برای محافظت از دادهها در برابر دسترسی غیرمجاز.
کامپیوترهایی هستند که منابع یا خدمات خاصی را در یک شبکه به دیگر سیستمها ارائه میدهند.
توابع ریاضی توابعی هستند که عملیاتهای ریاضی مانند جمع، تفریق، ضرب، تقسیم، ریشهگیری و لگاریتمگیری را انجام میدهند. این توابع معمولاً در کتابخانههای استاندارد مانند cmath در C++ موجود هستند.
فضای ذخیرهسازی آنلاین که به کاربران امکان میدهد اطلاعات خود را در سرورهای دور ذخیره کنند و از هر نقطهای به آنها دسترسی داشته باشند.
بینشهای مبتنی بر هوش مصنوعی به استفاده از الگوریتمهای هوش مصنوعی برای تجزیه و تحلیل دادهها و استخراج الگوهای کاربردی و پیشبینی آینده اشاره دارد.
اطلاعاتی است که به تشریح عملکرد سیستمها، نرمافزارها یا سختافزارها میپردازد.
سیگنالی که در آن اطلاعات به صورت گسسته و با دو سطح مشخص (0 و 1) منتقل میشود.
یکی از نخستین شبکههای کامپیوتری که به عنوان پیشگام توسعه اینترنت شناخته میشود.
شبکههای عصبی مصنوعی (ANN) به مدلهای ریاضی اشاره دارد که از ساختار مغز انسان الهام گرفتهاند و برای پردازش دادهها استفاده میشوند.
عملگر یا دستور برک برای خاتمه دادن به یک حلقه یا فرآیند در زمانی خاص استفاده میشود.
بازگشتی زمانی است که یک تابع یا روش، خود را فراخوانی میکند تا زمانی که شرط خاصی به حقیقت بپیوندد.
دیفای به سیستمهای مالی غیرمتمرکز اشاره دارد که با استفاده از فناوری بلاکچین ایجاد میشوند.
لجستیک هوشمند به استفاده از فناوریهای نوین مانند IoT، هوش مصنوعی و رباتها برای بهینهسازی عملیات حمل و نقل و ذخیرهسازی اشاره دارد.
این نوع رمزگذاری به شما امکان میدهد که دادههای رمزنگاریشده را بدون نیاز به رمزگشایی پردازش کنید. این تکنیک برای حفظ حریم خصوصی و امنیت دادهها در هنگام پردازش بسیار مهم است.
حلقه تو در تو به حالتی گفته میشود که یک حلقه درون حلقه دیگر قرار دارد. این نوع حلقهها برای انجام عملیاتهای پیچیدهتر به کار میروند.
این واژه به پردازش دادهها در نزدیکی محل ایجاد آنها (در لبه شبکه) اشاره دارد، بهجای ارسال دادهها به مراکز داده اصلی. این باعث کاهش تأخیر و مصرف پهنای باند میشود.
هرگونه سیگنال ناخواسته یا اختلال در سیگنالهای اصلی که میتواند بر کیفیت انتقال دادهها تأثیر بگذارد.
قراردادهای هوشمند قراردادهای دیجیتالی خوداجرایی هستند که قوانین و شرایط توافقنامهها را بهطور خودکار اجرا میکنند.
متغیر سراسری متغیری است که در خارج از توابع و بلوکهای کد تعریف میشود و در سراسر برنامه قابل دسترسی است.
هوش مصنوعی قابل توضیح (XAI) به طراحی سیستمهای هوش مصنوعی گفته میشود که میتوانند تصمیمات خود را بهطور شفاف و قابل فهم برای انسان توضیح دهند.
کامپایلر برنامهای است که کدهای نوشته شده در زبانهای سطح بالا را به زبان ماشین ترجمه میکند.
مدلهای مولد به سیستمهایی اطلاق میشود که قادر به ایجاد دادهها یا محتوای جدید مشابه دادههای واقعی هستند.
امنیت سایبری نسل بعدی به استفاده از تکنولوژیهای جدید برای شناسایی تهدیدات و محافظت از شبکهها و دادهها از حملات سایبری پیشرفته اطلاق میشود.
رویکردی است که به افراد کمک میکند تا مشکلات را نه به صورت جزئی، بلکه به عنوان بخشی از یک سیستم بزرگتر در نظر بگیرند. این نوع تفکر به ارزیابی ارتباطات میان اجزای مختلف یک سیستم کمک میکند.
یادگیری ماشین فدرال به الگوریتمهایی اطلاق میشود که دادهها در سرورهای مختلف باقی میمانند و تنها مدلهای آموزشدیده بهاشتراک گذاشته میشوند.
اضافه بار یا اوورفلو زمانی رخ میدهد که سیستم محاسباتی نمیتواند عددی بزرگتر از ظرفیت ذخیرهسازی خود را پردازش کند.
رباتهای جمعی به استفاده از رباتها برای انجام کارهای گروهی اشاره دارند که در آنها رباتها با همکاری یکدیگر وظایف را انجام میدهند.
تکرار به فرآیند اجرای دوباره یک دستور یا مجموعه دستورات گفته میشود. این واژه بیشتر در کنار حلقهها استفاده میشود.
پکتهایی که اطلاعات وضعیت لینکها را در پروتکلهای Link-State مانند IS-IS ارسال میکنند.
آرایه مجموعهای از دادهها است که به صورت یکپارچه ذخیره میشود و از اندیسها برای دسترسی به مقادیر مختلف آن استفاده میشود.
شبکهای که به اتصال چند شبکه LAN در یک ناحیه جغرافیایی محدود مانند محوطه دانشگاه پرداخته میشود.