تدوير قائمة بايثون
توفر لغة برمجة بايثون طرقًا عديدة لمعالجة القوائم، بما في ذلك مهمة تدوير عناصرها. يتضمن التدوير تحويل كل عنصر في القائمة بعدد محدد من المواضع في اتجاه محدد، إما إلى اليمين أو اليسار.
هناك طريقة بسيطة وفعالة لتدوير القائمة في بايثون من خلال التقطيع والتسلسل. يحدد التعليمة البرمجية التالية وظيفة تقوم بهذه العملية:
def rotate(l, n):
return l[-n:] l[:-n]
في هذه الوظيفة، يمثل l قائمة الإدخال، ويشير n إلى عدد المواضع المطلوب تدويرها. تقوم الدالة أولاً بإنشاء قائمتين جديدتين باستخدام التقطيع: l[-n:] وl[:-n]. يلتقط الأول العناصر الموجودة في نهاية القائمة، بينما يلتقط الأخير العناصر المتبقية. يتم بعد ذلك ربط القائمتين لتحقيق الدوران المطلوب.
على سبيل المثال، فكر في قائمة بايثون l أدناه:
l = [1, 2, 3, 4, 5]
إذا أردنا تدوير موضع واحد إلى اليمين، فسنسميه تدوير(l, 1):
rotated_l = rotate(l, 1)
print(rotated_l) # Output: [2, 3, 4, 5, 1]
في هذا المثال، يتم إزاحة العنصر الأول من القائمة الأصلية إلى النهاية، مما يؤدي إلى قائمة الإخراج [2, 3 , 4, 5, 1].
يمكن لوظيفة التدوير أيضًا التعامل مع القيم السالبة لـ n، والتي تشير إلى التدوير إلى اليسار. باستخدام n السالب، يتم نقل العناصر إلى اليمين بدلاً من اليسار.
rotated_l = rotate(l, -1)
print(rotated_l) # Output: [5, 1, 2, 3, 4]
في هذه الحالة، يتم تدوير l موضعًا واحدًا إلى اليسار، مما يؤدي إلى تحريك العنصر الأخير إلى الأمام.
من المهم ملاحظة أن وظيفة التدوير لا تقوم بتعديل قائمة الإدخال l. بدلاً من ذلك، يقوم بإنشاء قائمة جديدة بالعناصر التي تم تدويرها. يتوافق هذا السلوك مع تصميم القائمة غير القابل للتغيير في بايثون، حيث لا يُنصح بتعديل القائمة الأصلية.
تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.
Copyright© 2022 湘ICP备2022001581号-3