حل 6 تحديات برمجية من Edabit بأساليب بسيطة

هل تبحث عن طريقة ممتعة ومثيرة لتحسين مهاراتك في البرمجة؟ هل ترغب في اختبار معرفتك ومهاراتك في حل التحديات البرمجية؟ إذا، فقد وصلت إلى المكان المناسب! في هذا المقال، سنقدم لك حلولا رائعة لستة تحديات برمجية من منصة Edabit، وهي مناسبة للمبتدئين وتتنوع في صعوبتها لتوفير تجربة تعلم شاملة وممتعة.

حل 6 تحديات برمجية من Edabit بأساليب بسيطة

تحديات Edabit هي مصدر رائع لتحسين مهاراتك في البرمجة. تتضمن مجموعة متنوعة من التحديات التي تغطي مختلف المواضيع مثل الأرقام، السلاسل، القوائم، والخوارزميات. تم تصميم هذه التحديات لتكون ممتعة وتحفيزية، مما يجعلها مثالية للذين يرغبون في تحسين مهاراتهم البرمجية وفهم المفاهيم الأساسية بطريقة تفاعلية وممتعة.

في هذا المقال، سنقوم بتصوير رحلة مثيرة لحل ست تحديات برمجية مختلفة من Edabit. سنبدأ بتحديات بسيطة ونتقدم تدريجيا إلى التحديات ذات المستوى المتقدم. سنقدم لك لكل تحدي وصفا موجزا للمشكلة والخوارزمية المطلوبة، ثم سنعرض الحل المقترح ونشرح الكود البرمجي خطوة بخطوة.

تعرف على Edabit:

Edabit هي منصة تعليمية عبر الإنترنت مميزة تقدم مجموعة واسعة من التحديات البرمجية والأسئلة التفاعلية للمبرمجين في جميع المستويات. توفر Edabit بيئة تعلم فعالة وممتعة حيث يمكنك تحسين مهاراتك البرمجية واكتساب المزيد من الخبرة من خلال حل التحديات والممارسة العملية.

دعونا الآن نستعرض السحر والتحديات الستة التي سنقوم بحلها!

إليك أفضل ست تحديات برمجية وطرق حلها من موقع تحديات البرمجة Edabit.

حل 6 تحديات برمجية من Edabit بأساليب بسيطة

التحدي الأول: تحويل الساعات إلى ثوان

الوصف: اكتب دالة تحول الساعات إلى ثوان.

امثله:

how_many_seconds(2) ➞ 7200
how_many_seconds(10) ➞ 36000
how_many_seconds(24) ➞ 86400

ملاحظة:
60 ثانية في الدقيقة ، 60 دقيقة في الساعة
لا تنس إرجاع return إجابتك.

خوارزمية الحل:

هذا التحدي يتطلب كتابة دالة تقوم بتحويل عدد الساعات إلى عدد الثواني. لتحقيق ذلك، نحتاج إلى استخدام العلاقة التالية: 1 ساعة = 3600 ثانية.

  1. ابدأ بتعريف الدالة وتسميتها بـ how_many_seconds وتحديد المدخلات التي تتوقعها (عدد الساعات).
  2. ضرب عدد الساعات في 3600 لتحويلها إلى عدد الثواني.
  3. قم بإرجاع القيمة الناتجة كنتيجة للدالة.

هذه الخوارزمية تشرح الخطوات التي يجب اتباعها لحل التحدي بشكل عام، وتوضح كيفية تحويل عدد الساعات إلى عدد الثواني بواسطة الضرب في 3600.

شرح الكود:

هذا الكود يقوم بتحويل عدد الساعات إلى عدد الثواني ببساطة، وهو مبني على العلاقة الرياضية بين الوحدتين.


def how_many_seconds(hours):
    # تعريف الدالة مع اسمها والمعامل الذي يتم استقباله (عدد الساعات)
    
    # يتم تحويل عدد الساعات إلى عدد الثواني باستخدام العلاقة 1 ساعة = 3600 ثانية
    seconds = hours * 3600
    
    # يتم إرجاع عدد الثواني كنتيجة للدالة
    return seconds

ليصبح الكود كاملا كالاتي:


def hours_to_seconds(hours):
    seconds = hours * 3600  # There are 3600 seconds in an hour
    return seconds

# Example usage:
hours_input = 2
result = hours_to_seconds(hours_input)
print(f"{hours_input} hours is equal to {result} seconds.")

في هذا المثال ، تأخذ الدالة hours_to_seconds قيمة إدخال الساعات وتضربها في 3600 لتحويلها إلى ثوان. ثم يتم إرجاع النتيجة.

يمكنك استبدال المتغير hours_input بأي قيمة تريد تحويلها ، وستوفر الداله النتيجة المقابلة في ثوان.

ويكون مخرجات الكود كالاتي

2 hours is equal to 7200 seconds

حل 6 تحديات برمجية من Edabit بأساليب بسيطة

التحدي الثاني: إعادة جمع رقمين

الوصف:

يتطلب هذا التحدي إنشاء دالة تأخذ رقمين كمدخلات وتُرجع مجموعهما.

أمثلة:

addition(3, 2) ➞ 5
addition(-3, -6) ➞ -9
addition(7, 3) ➞ 10

المدخلات والمخرجات:

  • المدخلات: الدالة تأخذ رقمين كمدخلات (b و a).
  • المخرجات: تُرجع الدالة مجموع الرقمين.

القيود أو الشروط الخاصة:

  • لا توجد شروط خاصة، الدالة يجب أن تقوم بإضافة الرقمين المُدخلين وإرجاع الناتج.

خوارزمية الحل:

  1. ابدأ بتعريف الدالة وتسميتها addition وتحديد المدخلات التي تتوقعها (a و b).
  2. استخدم العملية الحسابية للجمع (+) لجمع الرقمين.
  3. قم بإرجاع القيمة الناتجة كنتيجة للدالة.

شرح الكود:

هذا الكود يحتوي على دالة تدعى addition تأخذ رقمين كمدخلات وتُرجع مجموعهما.
في الدالة، يتم استخدام العملية الحسابية (+) لجمع الرقمين وتخزين النتيجة في المتغير result، ثم يتم إرجاع النتيجة.
في هذا المثال، يتم استخدام الدالة لجمع رقمين (a و b)، ويتم طباعة الناتج.

شرح حل التحدي:

هذا التحدي يتمثل في كتابة دالة بسيطة تقوم بجمع رقمين وإرجاع الناتج. الحل البسيط يتمثل في استخدام العملية الحسابية للجمع مع استخدام عملية الإرجاع return لإعادة القيمة المحسوبة.

الكود مع شرح كل سطر:


def addition(a, b):
    # تعريف الدالة وتسميتها addition وتحديد المدخلات التي تتوقعها (a و b)

    result = a + b
    # استخدام العملية الحسابية للجمع (+) لجمع الرقمين وتخزين النتيجة في المتغير result

    return result
    # إرجاع القيمة الناتجة كنتيجة للدالة
إرجاع القيمة الناتجة كنتيجة للدالة

يتم استخدام هذه الدالة لجمع رقمين (a و b) وتخزين الناتج في total_sum، ثم يتم طباعة الناتج بواسطة الدالة print.

ليصبح الكود كاملا:


def addition(a, b):
    result = a + b
    return result

# Example usage:
a = 5
b = 7
total_sum = addition(a, b)
print(f"The sum of {a} and {b} is: {total_sum}")

ومخرجات الكود كالاتي:

The sum of 5 and 7 is: 12

حل 6 تحديات برمجية من Edabit بأساليب بسيطة

التحدي الثالث: رفع العدد إلى قوة

الوصف:

هذا التحدي يتطلب إنشاء دالة تأخذ رقما أساسيا ورقما مرتفعا وتعيد الحساب.

المدخلات والمخرجات:

  • المدخلات: الدالة تأخذ رقما أساسيا ورقما مرتفعا كمدخلات (num و exp).
  • المخرجات: تُرجع الدالة نتيجة رفع العدد إلى القوة.

القيود أو الشروط الخاصة:

  • لا توجد قيود أو شروط خاصة.

خوارزمية الحل:

  1. ابدأ بتعريف الدالة وتسميتها calculate_exponent وتحديد المدخلات التي تتوقعها (num و exp).
  2. استخدم عامل الأس (**) لرفع العدد num إلى قوة exp.
  3. قم بإرجاع النتيجة.

شرح الكود:

هذا الكود يحتوي على دالة تدعى calculate_exponent تأخذ رقمين كمدخلات وترجع نتيجة رفع العدد الأساسي إلى القوة المحددة.
يتم استخدام عامل الأس (**) في الدالة لرفع العدد num إلى قوة exp.
النتيجة تُطبع باستخدام دالة print مع القيم المختلفة للدخل.

شرح حل التحدي:

هذا التحدي يتمثل في كتابة دالة بسيطة تقوم برفع العدد num إلى قوة exp. الحل البسيط يتمثل في استخدام عامل الأس (**) للقيام بهذا الحساب.

الكود مع شرح كل سطر:


def calculate_exponent(num, exp):
    # تعريف الدالة وتسميتها calculate_exponent وتحديد المدخلات التي تتوقعها (num و exp)

    return num ** exp
    # استخدام عامل الأس (**) لرفع العدد num إلى قوة exp وإرجاع النتيجة

تم استخدام هذه الدالة لاختبار عدة أمثلة مع القيم المختلفة، والنتائج تُطبع للتحقق من صحة الحسابات.

ليصبح الكود كاملا:


def calculate_exponent(num, exp):
	return num ** exp

# Test the function with examples
print(calculate_exponent(5, 5))  # Output: 3125
print(calculate_exponent(3, 3))  # Output: 27

تحسب هذه الداله ببساطة نتيجة رفع القاعدة إلى قوة الأس باستخدام عامل الأس **.

حل 6 تحديات برمجية من Edabit بأساليب بسيطة

التحدي الرابع: تحويل الدقائق إلى ثواني

الوصف:

يطلب هذا التحدي كتابة دالة تأخذ عددا صحيحا يمثل الدقائق وتقوم بتحويله إلى ثوانٍ.

المدخلات والمخرجات:

  • المدخلات: الدالة تأخذ عددا صحيحا يمثل الدقائق.
  • المخرجات: تُرجع الدالة ناتج التحويل إلى ثوانٍ.

القيود أو الشروط الخاصة:

  • لا تنسى إرجاع النتيجة.

خوارزمية الحل:

  1. ابدأ بتعريف الدالة وتسميتها convert وتحديد المدخلات التي تتوقعها (minutes).
  2. ضرب عدد الدقائق في 60 لتحويلها إلى ثوانٍ.
  3. قم بإرجاع النتيجة.

شرح الكود:

هذا الكود يحتوي على دالة تُدعى convert تأخذ عددا صحيحا يمثل الدقائق وتُرجع النتيجة بعد تحويله إلى ثوانٍ.
يتم ضرب عدد الدقائق في 60 لتحويلها إلى ثوانٍ، ومن ثم يتم إرجاع النتيجة.

شرح حل التحدي:

هذا التحدي يتمثل في كتابة دالة بسيطة تقوم بتحويل عدد الدقائق إلى ثوانٍ. الحل البسيط يتمثل في استخدام العملية الحسابية للضرب بين عدد الدقائق والقيمة الثابتة 60 لتحويلها إلى ثوانٍ.

الكود مع شرح كل سطر:


def convert(minutes):
    # تعريف الدالة وتسميتها convert وتحديد المدخلات التي تتوقعها (minutes)

    return minutes * 60
    # ضرب عدد الدقائق في 60 لتحويلها إلى ثوانٍ وإرجاع النتيجة

تم استخدام هذه الدالة لاختبار عدة أمثلة مع القيم المختلفة، والنتائج تطبع للتحقق من صحة الحسابات.

ليصبح الكود كاملا:


def convert(minutes):
    return minutes * 60

# Test cases
print(convert(5))  # Output: 300
print(convert(3))  # Output: 180
print(convert(2))  # Output: 120

تحدد هذه الخوارزمية تحويل دالة تستغرق دقائق صحيحة كإدخال ، وتضربها في 60 لتحويل الدقائق إلى ثوان ، وترجع النتيجة.

التحدي الخامس: تحويل قيمة منطقية إلى نص

الوصف:

هذا التحدي يطلب كتابة دالة تأخذ متغير منطقي وتُعيد قيمته كنص

المدخلات والمخرجات:

  • المدخلات: الدالة تأخذ متغير منطقي.
  • المخرجات: تُرجع الدالة قيمته كنص.

القيود أو الشروط الخاصة:

  • لا تنسى إرجاع النتيجة.

خوارزمية الحل:

  1. ابدأ بتعريف الدالة وتسميتها bool_to_string وتحديد المدخلات التي تتوقعها (flag).
  2. استخدم دالة ()str لتحويل القيمة المنطقية إلى نص.
  3. قم بإرجاع النص الناتج.

شرح الكود:

هذا الكود يحتوي على دالة تُدعى bool_to_string تأخذ متغير منطقي وتُعيد قيمته كنص.
يتم استخدام دالة ()str لتحويل القيمة البوليانية إلى نص، ثم يتم إرجاع النتيجة.

شرح حل التحدي:

هذا التحدي يتمثل في كتابة دالة بسيطة تقوم بتحويل قيمة بوليانية إلى نص. الحل البسيط يتمثل في استخدام دالة ()str لتحويل القيمة المنطقية إلى نص.

الكود مع شرح كل سطر:


def bool_to_string(flag):
    # تعريف الدالة وتسميتها bool_to_string وتحديد المدخلات التي تتوقعها (flag)

    return str(flag)
    # استخدام دالة str() لتحويل القيمة البوليانية إلى نص وإرجاع النتيجة

تم استخدام هذه الدالة لاختبار عدة أمثلة مع القيم المختلفة، والنتائج تُطبع للتحقق من صحة الحسابات.

ليصبح الكود كاملا:


def bool_to_string(flag):
    return str(flag)

# Test cases
print(bool_to_string(True))   # Output: "True"
print(bool_to_string(False))  # Output: "False"

تقوم هذه الدالة ببساطة بتحويل القيمة المنطقية إلى سلسلة باستخدام الدالة ()str وإرجاع النتيجة.

حل 6 تحديات برمجية من Edabit بأساليب بسيطة

التحدي السادس: إعادة العدد التالي بناءً على العدد الصحيح

الوصف:

هذا التحدي يتطلب إنشاء دالة تأخذ عددا كمُعامل، تقوم بزيادة هذا العدد بـ +1 وتُعيد النتيجة.

المدخلات والمخرجات:

  • المدخلات: الدالة تأخذ عددا كمُعامل.
  • المخرجات: تُعيد الدالة العدد المزيد بناءً على العدد المُمرر.

القيود أو الشروط الخاصة:

  • لا تنسى إرجاع النتيجة.

خوارزمية الحل:

  1. ابدأ بتعريف الدالة وتسميتها addition وتحديد المدخلات التي تتوقعها (num).
  2. زيادة قيمة العدد الممرر بواحد.
  3. قم بإرجاع النتيجة.

شرح الكود:

يحتوي الكود على دالة تُدعى addition والتي تأخذ عددًا كمُعامل، وتقوم بزيادة هذا العدد بـ +1 باستخدام عامل الجمع، ثم تُرجع الناتج.

شرح حل التحدي:

التحدي يطلب ببساطة كتابة دالة تُزيد قيمة العدد الممرر إليها بـ1 وتُرجع الناتج. الحل البسيط يتمثل في استخدام عامل الجمع لزيادة العدد الممرر بـ1.

الكود مع التعليقات لشرح كل سطر:


def addition(num):
    # تعريف الدالة وتسميتها addition وتحديد المدخلات التي تتوقعها (num)

    return num + 1
    # زيادة قيمة العدد الممرر بواحد وإرجاع النتيجة

تم استخدام هذه الدالة لاختبار عدة أمثلة مع القيم المختلفة للدخل، والنتائج تُطبع للتحقق من صحة الحسابات.

ليصبح الكود كاملا:


def addition(num):
    return num + 1

# Test cases
print(addition(0))   # Output: 1
print(addition(9))   # Output: 10
print(addition(-3))  # Output: -2

وصلنا إلى نهاية هذه الرحلة الممتعة في عالم حل التحديات البرمجية من موقع Edabit. قدمنا خلال هذا المقال حلولًا مبتكرة وبسيطة لستة تحديات، واكتشفنا الكثير من الخوارزميات والمفاهيم البرمجية. لكن المغامرة لا تنتهي هنا! إن عالم البرمجة واسع ومليء بالإمكانيات والتحديات التي تنتظرك لتستكشفها وتتحدى نفسك فيها.

استمر في رحلتك في عالم البرمجة بحماس وفضول، ولا تنسى دائمًا أن التحديات هي فرصة للتعلم والنمو. قم بتطوير مهاراتك وتوسيع معرفتك، وكن دائمًا على استعداد لمواجهة التحديات الجديدة والتغلب عليها بإبداعك ومهاراتك. دع البرمجة تكون لك لغة للتعبير عن أفكارك وإحدى وسائل تحقيق أحلامك.

بهذه الخاتمة، نتمنى لك كل التوفيق في رحلتك البرمجية، ونتطلع لرؤية إبداعاتك وإنجازاتك المستقبلية. ابدأ الآن بتحدي نفسك واستمتع بكل لحظة في رحلتك البرمجية!

مع أطيب التمنيات،

محمد موسي
بواسطة : محمد موسي
مطور واجهات أمامية وصانع محتوى لدي شغف بتصميم وتطوير مواقع الويب وتطوير ووردبريس وكتابة المقالات. متابع لأحدث اتجاهات التصميم والتطوير على الويب. لدي خبره سابقا في منتديات الدعم الفني والمدونات ، احترف كتابه المحتوي من عام 2017 لتقديم محتوي راقي ومفيد.
تعليقات



حجم الخط
+
16
-
تباعد السطور
+
2
-