شبکهای که از سنسورهای بیسیمی تشکیل میشود که میتوان آنها را حمل کرده یا درون لباس تعبیه کرد.
پیمایش (Traversal) در علوم کامپیوتر به معنای بازدید از تمامی گرهها یا عناصر یک ساختار دادهای به منظور انجام عملیات خاصی روی آنها است. عملیات پیمایش یکی از اجزای اساسی در بسیاری از الگوریتمها و ساختارهای دادهای مانند درختها، گرافها و لیستها است. در این فرایند، هدف این است که به هر گره یا عنصر از ساختار داده دسترسی پیدا کرده و عملیاتهای مختلفی مانند جستجو، ویرایش یا نمایش دادهها را انجام دهیم.
پیمایش در ساختارهای دادهای مختلف میتواند به روشهای مختلفی انجام شود. در اینجا به بررسی چند نوع اصلی پیمایش میپردازیم که بیشتر در درختها و گرافها کاربرد دارند:
در پیمایش پیشوندی، ابتدا داده گره جاری بازدید میشود، سپس به ترتیب گرههای فرزند چپ و راست (در درختهای دودویی) بازدید میشوند. این نوع پیمایش بهویژه در زمانی که نیاز به ذخیرهسازی ساختار درخت یا انجام عملیاتی قبل از بررسی فرزندان است، کاربرد دارد.
# پیمایش پیشوندی درخت دودویی def pre_order(node):
if node:
print(node.data, end=" ") # بازدید از گره جاری
pre_order(node.left) # پیمایش فرزند چپ
pre_order(node.right) # پیمایش فرزند راست در پیمایش پسوندی، ابتدا فرزندان چپ و راست بازدید میشوند و سپس داده گره جاری. این نوع پیمایش معمولاً در مواردی که لازم است ابتدا تمامی عملیاتهای فرزندان انجام شوند و سپس عملیات روی گره جاری انجام گردد، مفید است.
# پیمایش پسوندی درخت دودویی def post_order(node):
if node:
post_order(node.left) # پیمایش فرزند چپ
post_order(node.right) # پیمایش فرزند راست
print(node.data, end=" ") # بازدید از گره جاری در پیمایش میانهای، ابتدا گره فرزند چپ بازدید میشود، سپس داده گره جاری و در نهایت فرزند راست بازدید میشود. این نوع پیمایش بهویژه در درختهای دودویی جستجو (Binary Search Tree) کاربرد دارد، زیرا با این روش، دادهها به ترتیب مرتب شده نمایش داده میشوند.
# پیمایش میانهای درخت دودویی def in_order(node):
if node:
in_order(node.left) # پیمایش فرزند چپ
print(node.data, end=" ") # بازدید از گره جاری
in_order(node.right) # پیمایش فرزند راست در پیمایش سطح به سطح (که به آن پیمایش به روش صف نیز گفته میشود)، ابتدا گره ریشه بازدید میشود، سپس گرههای هر سطح از درخت به ترتیب از چپ به راست بررسی میشوند. این نوع پیمایش معمولاً با استفاده از صف (Queue) انجام میشود.
# پیمایش سطح به سطح درخت دودویی با استفاده از صف from collections import deque def level_order(root):
if root is None:
return
queue = deque([root])
while queue:
node = queue.popleft()
print(node.data, end=" ")
if node.left:
queue.append(node.left)
if node.right:
queue.append(node.right) پیمایش در گرافها به دو روش اصلی انجام میشود: پیمایش به روش عمق اول (DFS) و پیمایش به روش عرض اول (BFS).
در این روش، ابتدا یک گره انتخاب میشود، سپس بهطور عمقی به سراغ فرزندهای آن گره میرود تا زمانی که به گرهای برسد که دیگر فرزند نداشته باشد یا به گرهی که قبلاً بازدید شده است، برخورد کند.
# پیمایش به روش عمق اول (DFS) با استفاده از بازگشت def dfs(node, visited):
if node not in visited:
print(node.data, end=" ")
visited.add(node)
for neighbor in node.neighbors:
dfs(neighbor, visited) در این روش، ابتدا گره ریشه بازدید میشود، سپس بهطور عرضی به بررسی گرههای همسطح پرداخته میشود. این پیمایش معمولاً با استفاده از صف (Queue) انجام میشود.
# پیمایش به روش عرض اول (BFS) با استفاده از صف def bfs(root):
if not root:
return
queue = deque([root])
visited = set([root])
while queue:
node = queue.popleft()
print(node.data, end=" ")
for neighbor in node.neighbors:
if neighbor not in visited:
visited.add(neighbor)
queue.append(neighbor) پیمایشها در بسیاری از مسائل کاربرد دارند، از جمله:
در نهایت، پیمایش یکی از عملیاتهای اساسی در علوم کامپیوتر است که برای دسترسی و پردازش دادهها در ساختارهای دادهای مختلف بهکار میرود. برای آشنایی بیشتر با مفاهیم پیمایش و دیگر ساختارهای دادهای، میتوانید به سایت saeidsafaei.ir مراجعه کنید و از اسلایدهای محمد سعید صفایی بهرهمند شوید.
در این مبحث، به شناخت، انواع و طرز استفاده از آرایهها پرداخته میشود و چندین مثال عملی با استفاده از فلوچارت و آرایهها رسم خواهیم کرد. همچنین، با توجه به اهمیت فلوچارت در طراحی الگوریتمها، در بخش دوم اسلایدها، چندین تمرین مهم با رسم فلوچارت در اختیار شما قرار خواهد گرفت تا مهارتهای عملی شما در این زمینه تقویت شود.
شبکهای که از سنسورهای بیسیمی تشکیل میشود که میتوان آنها را حمل کرده یا درون لباس تعبیه کرد.
متغیر در برنامهنویسی به فضایی در حافظه گفته میشود که برای ذخیره دادهها استفاده میشود. این دادهها میتوانند در طول اجرای برنامه تغییر کنند.
عملگرهای منطقی برای مقایسه و ارزیابی عبارات منطقی استفاده میشوند و میتوانند نتیجهای درست یا غلط را تولید کنند.
نماد مستطیل در فلوچارت که برای نمایش انجام محاسبات یا فرایندهای مختلف مانند جمع، تفریق و انتساب استفاده میشود.
عملگر مودولو برای بهدست آوردن باقیمانده یک تقسیم استفاده میشود. به عنوان مثال، 7 % 3 برابر با 1 است.
در این توپولوژی، انتقال اطلاعات در لحظه فقط در یک جهت انجام میشود. هر نود شبکه به یک کابل متصل است.
متغیر محلی متغیری است که تنها در داخل یک بلوک از کد یا یک تابع قابل دسترسی است و پس از پایان آن بلوک از حافظه حذف میشود.
عملیاتهای ریاضی روی اشارهگرها به معنای تغییر موقعیت حافظه است که میتواند برای دسترسی به دادهها و پردازش آنها استفاده شود.
هوش افزوده به تقویت توانمندیهای انسانی از طریق تکنولوژیهای هوش مصنوعی گفته میشود تا تصمیمگیریهای بهتری صورت گیرد.
امنیت لبه به استفاده از روشها و ابزارهای امنیتی برای حفاظت از دادهها و دستگاههای متصل در لبه شبکه اطلاق میشود.
قسمت اعشاری یا کسری یک عدد که در سیستمهای عددی به خصوص در مبنای 10 یا 2 نمایش داده میشود.
کدی که برای گسترش دادهها در سیستمهای CDMA استفاده میشود تا از تداخل جلوگیری کرده و دادهها را از یکدیگر تفکیک کند.
نوعی VLAN که به دستگاهها اجازه میدهد در یک VLAN مشترک باشند اما نتوانند به یکدیگر دسترسی داشته باشند.
کشف دادههای افزوده به فرآیند تجزیه و تحلیل و استخراج الگوهای جدید از دادههای موجود به کمک هوش مصنوعی گفته میشود.
مرزهای IoT به دستگاههای فیزیکی در شبکههای IoT اطلاق میشود که قادر به انجام پردازش و تحلیل دادهها در لبه شبکه هستند.
دستگاهی که برای متصل کردن چندین شبکه محلی LAN به یکدیگر استفاده میشود و در لایه دادهلینک (Layer 2) عمل میکند.
لجستیک هوشمند به استفاده از فناوریهای نوین مانند IoT، هوش مصنوعی و رباتها برای بهینهسازی عملیات حمل و نقل و ذخیرهسازی اشاره دارد.
محاسبات ژنومی به استفاده از تکنیکهای محاسباتی برای تجزیه و تحلیل دادههای ژنتیکی و ژنومیک اطلاق میشود.
یادگیری فدرال به روشی برای آموزش مدلهای یادگیری ماشین گفته میشود که دادهها در دستگاههای محلی باقی میمانند و تنها مدلهای آموزش دیده با یکدیگر به اشتراک گذاشته میشوند.
خودروهای خودران به خودروهایی اطلاق میشود که میتوانند بدون دخالت انسان حرکت کنند و تصمیمات رانندگی را اتخاذ کنند.
روشی برای توصیف سیستمها با استفاده از مدلهای ریاضی است. سیستمهایی که اطلاعات کمی از آنها داریم، به صورت 'جعبه سیاه' مدل میشوند، در حالی که سیستمهایی که اطلاعات بیشتری در مورد آنها داریم، به صورت 'جعبه سفید' مدل میشوند.
عملیاتهای سطح بیت مانند AND، OR، NOT و XOR که بر روی هر بیت از دادهها انجام میشوند.
دستکاری رشتهها به مجموعه عملیاتهایی اطلاق میشود که میتوان روی رشتهها انجام داد، مانند الحاق، تقسیم، جستجو و تغییر مقادیر.
پردازش سیگنال دیجیتال (DSP) به استفاده از الگوریتمها برای تجزیه و تحلیل و پردازش سیگنالهای دیجیتال برای کاربردهای مختلف اطلاق میشود.
الگوریتمهای ژنتیک به روشهای محاسباتی اطلاق میشود که از فرآیندهای طبیعی تکامل برای حل مسائل پیچیده استفاده میکنند.
نگهداری پیشبینی در صنعت به استفاده از دادههای تاریخچهای و الگوریتمها برای پیشبینی خرابی و نیاز به تعمیر در تجهیزات صنعتی اشاره دارد.
کابلهای زوج به هم تابیده با غلاف فلزی برای کاهش تداخل الکترومغناطیسی.
غلبه کوانتومی به توانایی سیستمهای کوانتومی در حل مسائل پیچیدهای اطلاق میشود که برای رایانههای کلاسیک غیرممکن است.
هوش مصنوعی (AI) به سیستمهایی اطلاق میشود که توانایی انجام کارهایی که نیاز به هوش انسانی دارند را دارند.
روشی برای انجام محاسبات به طور همزمان و با استفاده از منابع مختلف مانند پردازندههای متعدد به منظور تسریع در اجرای برنامه.
فاکتوریل یک عدد n با ضرب آن در تمام اعداد صحیح مثبت کوچکتر از خودش تعریف میشود. این مقادیر بهطور معمول برای محاسبات ریاضی یا بازگشتی استفاده میشوند.
گراف وزنی گرافی است که در آن به هر یال یک وزن یا هزینه اختصاص داده میشود.
خروجی به نتایج حاصل از پردازش دادهها گفته میشود که پس از انجام عملیاتها به کاربر یا سیستم دیگری ارسال میشود.
نویز ناشی از میدانهای الکترومغناطیسی که از تجهیزات الکتریکی و الکترونیکی ایجاد میشود.
اطلاعاتی است که به تشریح عملکرد سیستمها، نرمافزارها یا سختافزارها میپردازد.