တွက်ချက်ပြီး Python တွင် အကြီးဆုံး ဘုံကိန်းခွဲနှင့် အနည်းဆုံး အများကိန်းကို ရယူပါ။

စီးပွားရေးလုပ်ငန်း

အောက်ဖော်ပြပါသည် Python တွင် အကြီးမားဆုံးဘုံကိန်းကိန်းနှင့် ဘုံကိန်းအနည်းဆုံးကို တွက်ချက်နည်းနှင့် ရယူနည်း၏ ဖော်ပြချက်ဖြစ်သည်။

  • ကိန်းပြည့် နှစ်ခု၏ အကြီးမားဆုံး ဘုံကိန်း နှင့် အနည်းဆုံး ဘုံကိန်း
  • သုံးလုံး သို့မဟုတ် ထို့ထက်ပိုသော ကိန်းပြည့်များ၏ အကြီးမြတ်ဆုံး ဘုံကိန်းနှင့် အနည်းဆုံး ဘုံကိန်း

စံဒစ်ဂျစ်တိုက်တွင် ပေးထားသည့် လုပ်ဆောင်ချက်များ၏ သတ်မှတ်ချက်များသည် Python ဗားရှင်းပေါ်မူတည်၍ ကွဲပြားသည်ကို သတိပြုပါ။ စံဒစ်ဂျစ်တိုက်တွင်မရှိသော လုပ်ဆောင်ချက်တစ်ခုကို နမူနာအကောင်အထည်ဖော်မှုကိုလည်း ဤဆောင်းပါးတွင် ပြထားသည်။

  • Python 3.4 နှင့်အထက်
    • GCD:fractions.gcd()(အငြင်းအခုံနှစ်ခုသာ)
  • Python 3.5 နှင့်အထက်
    • GCD:math.gcd()(အငြင်းအခုံနှစ်ခုသာ)
  • Python 3.9 နှင့်အထက်
    • GCD:math.gcd()(အငြင်းအခုံ ၃ ခုထက်ပို၍ ထောက်ခံသည်)
    • ဘုံပိုင်းခြေအနည်းဆုံး:math.lcm()(အငြင်းအခုံ ၃ ခုထက်ပို၍ ထောက်ခံသည်)

ဤတွင် ကျွန်ုပ်တို့သည် ပုံမှန် Python စာကြည့်တိုက်ကို အသုံးပြုသည့် နည်းလမ်းကို ရှင်းပြပါသည်။ NumPy သည် များစွာသော arrays တစ်ခုစီ၏ ဒြပ်စင်တစ်ခုစီအတွက် အကြီးမားဆုံး ဘုံကိန်းကိန်းနှင့် အနည်းဆုံး ဘုံကိန်းများကို တွက်ချက်ရန် အလွယ်တကူ အသုံးပြုနိုင်သည်။

ကိန်းပြည့် နှစ်ခု၏ အကြီးမားဆုံး ဘုံကိန်း နှင့် အနည်းဆုံး ဘုံကိန်း

GCD

Python 3.5 မှစတင်၍ math module တွင် gcd() function တစ်ခုရှိသည်။ gcd() သည် အတိုကောက်ဖြစ်သည်။

  • greatest common divisor

အငြင်းအခုံတွင် သတ်မှတ်ထားသည့် ကိန်းပြည့်၏ အကြီးဆုံးဘုံပိုင်းခြားမှုကို ပြန်ပေးသည်။

import math

print(math.gcd(6, 4))
# 2

Python 3.4 နှင့် အစောပိုင်းတွင်၊ gcd() လုပ်ဆောင်ချက်သည် သင်္ချာ module မဟုတ်ဘဲ အပိုင်းကိန်းများ module တွင် ရှိနေကြောင်း သတိပြုပါ။ အပိုင်းများကို တင်သွင်းပြီး fractions.gcd() ရပါမည်။

ဘုံပိုင်းခြေအနည်းဆုံး

အနည်း ဆုံး အများကိန်းကို ပြန်ပေးသည့် lcm() လုပ်ဆောင်ချက်ကို Python 3.9 ရှိ သင်္ချာ module တွင် ထည့်သွင်းခဲ့သည်။ lcm သည် အတိုကောက်ဖြစ်သည်။

  • least common multiple

အငြင်းအခုံတွင် သတ်မှတ်ထားသည့် ကိန်းပြည့်၏ အနည်းဆုံးအသုံးအများဆုံးကို ပြန်ပေးသည်။

print(math.lcm(6, 4))
# 12

Python 3.8 မတိုင်မီတွင် lcm() ကို မပေးထားသော်လည်း gcd() ကို အသုံးပြု၍ အလွယ်တကူ တွက်ချက်နိုင်သည်။

lcm(a, b) = a * b / gcd(a, b)

အကောင်အထည်ဖော်မှု ဥပမာ။

def my_lcm(x, y):
    return (x * y) // math.gcd(x, y)

print(my_lcm(6, 4))
# 12

/၎င်းသည် ဒဿမမျှောတ်တစ်ခုအဖြစ် ရလဒ်ထွက်လာသောကြောင့်၊ ဒဿမအမှတ်ကို ဖြတ်တောက်ပြီး ကိန်းပြည့်ခွဲခြင်းရလဒ်ကို ပြန်ပေးရန်အတွက် backslash နှစ်ခုကို အသုံးပြုသည်။ အငြင်းအခုံသည် ကိန်းပြည့်ဟုတ်မဟုတ် ဆုံးဖြတ်ရန် စီမံဆောင်ရွက်ခြင်းကို မလုပ်ဆောင်ကြောင်း သတိပြုပါ။

သုံးလုံး သို့မဟုတ် ထို့ထက်ပိုသော ကိန်းပြည့်များ၏ အကြီးမြတ်ဆုံး ဘုံကိန်းနှင့် အနည်းဆုံး ဘုံကိန်း

Python 3.9 နှင့်အထက်

Python 3.9 မှစတင်၍ အောက်ပါလုပ်ဆောင်ချက်များအားလုံးသည် အကြောင်းပြချက်သုံးခုထက်ပို၍ ပံ့ပိုးပေးပါသည်။

  • math.gcd()
  • math.lcm()
print(math.gcd(27, 18, 9))
# 9

print(math.gcd(27, 18, 9, 3))
# 3

print(math.lcm(27, 9, 3))
# 27

print(math.lcm(27, 18, 9, 3))
# 54

*စာရင်းတစ်ခု၏ အကြီးမြတ်ဆုံး ဘုံပိုင်းခြားမှု သို့မဟုတ် အနည်းဆုံး ဘုံကိန်းဂဏန်းကို တွက်ချက်လိုပါက၊ ၎င်းနှင့် ငြင်းခုံမှုကို သတ်မှတ်ပါ။

l = [27, 18, 9, 3]
print(math.gcd(*l))
# 3

print(math.lcm(*l))
# 54

Python 3.8 နှင့်အထက်

Python 3.8 မတိုင်မီ၊ gcd() လုပ်ဆောင်ချက်သည် အကြောင်းပြချက်နှစ်ခုသာ ပံ့ပိုးပေးထားသည်။

ကိန်းပြည့်သုံးလုံး သို့မဟုတ် ထို့ထက်ပိုသော ဘုံကိန်းတန်း သို့မဟုတ် အနည်းဆုံး ဘုံကိန်းကို ရှာဖွေရန်၊ အထူးရှုပ်ထွေးသော အယ်လဂိုရီသမ် မလိုအပ်ပါ။ များပြားသောတန်ဖိုးတစ်ခုစီအတွက် အကြီးမြတ်ဆုံးဘုံခွဲဝေမှု သို့မဟုတ် ဘုံကိန်းဂဏန်းများကိုသာ တွက်ချက်ပြီး ပိုမိုမြင့်မားသောအမှာစာလုပ်ဆောင်ချက်ကို reduce() ကို အသုံးပြု၍ တွက်ချက်ပါ။

GCD

from functools import reduce

def my_gcd(*numbers):
    return reduce(math.gcd, numbers)

print(my_gcd(27, 18, 9))
# 9

print(my_gcd(27, 18, 9, 3))
# 3

l = [27, 18, 9, 3]
print(my_gcd(*l))
# 3

တစ်ဖန်၊ Python 3.4 မတိုင်မီတွင်၊ gcd() လုပ်ဆောင်ချက်သည် သင်္ချာ module မဟုတ်ဘဲ အပိုင်းပိုင်း module တွင် ရှိနေကြောင်း သတိပြုပါ။

ဘုံပိုင်းခြေအနည်းဆုံး

def my_lcm_base(x, y):
    return (x * y) // math.gcd(x, y)

def my_lcm(*numbers):
    return reduce(my_lcm_base, numbers, 1)

print(my_lcm(27, 9, 3))
# 27

print(my_lcm(27, 18, 9, 3))
# 54

l = [27, 18, 9, 3]
print(my_lcm(*l))
# 54