TheBrain نشر 27 ديسمبر 2015 أرسل تقرير نشر 27 ديسمبر 2015 أملك قائمة متكونة من أعداد صحيحة مرتبة من الأصغر للأكبر كما تظهر في المثال التالي:a=[1,1,1,1,2,2,2,2,3,3,4,5,5]أحتاج إلى حساب عدد تكرارات كل عنصر في هذه القائمة وأريد الناتج أن يكون قائمة تحتوي على عدد تكرارات كل عنصر كما في المثال التالي:b = [4,4,2,1,2] فما هي اسهل طريقة لفعل ذلك في البايثون؟ اقتباس
0 Blackhacker نشر 27 ديسمبر 2015 أرسل تقرير نشر 27 ديسمبر 2015 هنالك طرق عديدة في لغة بايثون لحساب عدد تكرارات عناصرها، وبما أن السلسلة النصية مرتبة فسيصبح أمر ترتيبها سهل للغاية.يمكنك استخدام دالة groupby من وحدة itertools مع دوال len و list وحلقة تكرار for للحصول على ما تريد:a = [1,1,1,1,2,2,2,2,3,3,4,5,5] from itertools import groupby [len(list(group)) for key, group in groupby(a)] وسيكون الناتج:[4, 4, 2, 1, 2] أما إذا كنت تستخدم الإصدار 2.7 من بايثون فيمكنك في هذه الحالة استخدام دالة Counter من وحدة collections حيث ستحصل بهذه الطريقة على قاموس يحتوي على العناصر وعدد مرات تكرار وإذا أردت الحصول على عدد مرات التكرار فقط فيمكنك استخدام دالة values() كما في المثال التالي:import collections a = [1,1,1,1,2,2,2,2,3,3,4,5,5] counter=collections.Counter(a) print(counter) # Counter({1: 4, 2: 4, 3: 2, 5: 2, 4: 1}) print(counter.values()) # [4, 4, 2, 1, 2] print(counter.keys()) # [1, 2, 3, 4, 5] print(counter.most_common(3)) # [(1, 4), (2, 4), (3, 2)] اقتباس
السؤال
TheBrain
أملك قائمة متكونة من أعداد صحيحة مرتبة من الأصغر للأكبر كما تظهر في المثال التالي:
a=[1,1,1,1,2,2,2,2,3,3,4,5,5]
أحتاج إلى حساب عدد تكرارات كل عنصر في هذه القائمة وأريد الناتج أن يكون قائمة تحتوي على عدد تكرارات كل عنصر كما في المثال التالي:
b = [4,4,2,1,2]
فما هي اسهل طريقة لفعل ذلك في البايثون؟
1 جواب على هذا السؤال
Recommended Posts
انضم إلى النقاش
يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.