أداء الفرق بين العناصر في القوائم: Lambda مقابل فهم القائمة
يعد البحث عن الاختلافات بين العناصر المتجاورة في القائمة عملية شائعة في برمجة. في بايثون، هناك عدة طرق لتحقيق ذلك، بما في ذلك استخدام تعبيرات لامدا أو فهم القائمة.
تعبير لامدا:
يمكن استخدام تعبير لامدا لإنشاء دالة. سريعًا، والذي يمكن بعد ذلك استخدامه للعمل على كل عنصر في القائمة. على سبيل المثال:t = [1, 3, 6]
differences = list(map(lambda i, j: j - i, t[:-1], t[1:]))
في هذه الحالة، دالة lambda lambda i, j: j - i يطرح العنصر (i) من العنصر (i 1) الخاص به. تقوم وظيفة الخريطة بعد ذلك بتطبيق هذه الوظيفة على كل زوج من العناصر المتجاورة في القائمة. فهم القائمة:
توفر فهم القائمة طريقة موجزة لإنشاء قائمة جديدة تعتمد على في القائمة الموجودة. يقوم فهم القائمة التالية بتنفيذ نفس العملية مثل تعبير لامدا أعلاه:
differences = [j - i for i, j in zip(t[:-1], t[1:])]differences = [j - i for i, j in zip(t[:-1], t[1:])]
المقارنة:كلا النهجين لهما مزايا وعيوب. تعد تعبيرات Lambda أكثر تنوعًا ويمكن استخدامها في نطاق أوسع من المواقف. ومع ذلك، فإن فهم القائمة غالبًا ما يكون أكثر إيجازًا وأسهل في القراءة.
مثال:
بالنظر إلى القائمة t = [1، 3، 6]، فإن كلا تعبيري لامدا وسينتج عن فهم القائمة المخرجات التالية:
[2, 3]وذلك لأن الفرق الأول (3 - 1) هو 2، والفرق الثاني (6 - 3) هو 3.تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.
Copyright© 2022 湘ICP备2022001581号-3