الخوارزميات و هياكل البيانات التحدي السابع - حل التمرين الرابع بلغة بايثون

المطلوب

أكتب برنامج مهمته رسم الشكل التالي بواسطة الحلقات و حاول كتابة أصغر كود ممكن.
عند تشغيل البرنامج, يجب أن يطلب من المستخدم إدخال عدد أسطر الشكل الذي سيتم رسمه.
إنتبه: يجب أن يدخل المستخدم عدد مفرد و أكبر من صفر, لأن عدد الأسطر لا يمكن أن يكون مزدوجاً أو قيمته تساوي صفر أو أقل من صفر.


الحل بلغة بايثون

n = 0

while n <= 0 or n % 2 == 0:
    n = int(input("Enter and odd number as the number of lines: "))

for i in range(1, n + 1):

    for j in range(1, n + 1):

        if (i == 1 or i == n or j == int(n / 2) or j == int(n / 2) + 2 or i == j or j == n - i + 1)\
                and i != int(n / 2) + 1 and j != int(n / 2) + 1:
            print('*', end='')

        else:
            print(' ', end='')

    print()
		

سنحصل على النتيجة التالية إذا قام المستخدم بإدخال الرقم 11 عند التشغيل.

Enter an odd number as the number of lines: 11
***** *****
 *  * *  * 
  * * * *  
   ** **   
    * *    
           
    * *    
   ** **   
  * * * *  
 *  * *  * 
***** *****
		

ملاحظة

الشكل الذي يظهر لك في النتيجة النهائية مطابق تماماً للشكل المطلوب و لكنه لا يظهر مشابهاً له 100% بسبب الهامش الإفتراضي الذي يقوم الحاسوب بوضعه بين الأسطر.

للتأكد من النتيجة بشكل دقيق, قم بعد عدد النجوم و المسافات الفارغة الموجودة في كل سطر.

الدورات

أدوات مساعدة

أقسام الموقع

دورات
مقالات كتب مشاريع أسئلة