۶۵ دیدگاه نظر عبدالرضا مولایی
برنامه ی فرمول تشخیص عدد اول در پایتون
سرفصل‌های مقاله
  • نوشتن برنامه تشخیص عدد اول با پایتون
  • پیاده‌سازی الگوریتم سوم در پایتون
  • نوشتن تابع تشخیص عدد اول
  • چاپ اعداد ۱ تا ۱۰۰ به‌جز مضارب عدد ۴ در پایتون
  • جمع بندی

برنامه‌نویسی تنها نوشتن کد نیست، بلکه یاد گرفتن روش فکر کردن برای حل مسئله است. یکی از تمرین‌های کلاسیک و بسیار مفید در این مسیر، نوشتن برنامه‌ای برای تشخیص عدد اول است؛ مسئله‌ای ساده در ظاهر، اما مناسب برای درک مفاهیمی مانند ورودی، حلقه، شرط و الگوریتم.

در این مقاله، با نوشتن یک برنامه تشخیص عدد اول در پایتون، قدم‌به‌قدم با فرآیند تحلیل مسئله، طراحی الگوریتم و پیاده‌سازی آن آشنا می‌شویم.

نوشتن برنامه تشخیص عدد اول با پایتون

مسئله: برنامه‌ای بنویسید که یک عدد صحیح از کاربر دریافت کند و مشخص کند آیا این عدد، عدد اول است یا خیر.

برای حل هر مسئله برنامه‌نویسی، ابتدا باید دقیقاً بدانیم مسئله چه چیزی از ما می‌خواهد. در اینجا دو مرحله اصلی داریم:

  • دریافت یک عدد صحیح از کاربر
  • بررسی اول بودن یا نبودن عدد وارد شده

برای انجام مرحله دوم، ابتدا باید تعریف دقیقی از «عدد اول» داشته باشیم و سپس الگوریتم مناسبی برای تشخیص آن انتخاب کنیم.

عدد اول چیست؟

عدد اول عددی است که فقط بر ۱ و خودش بخش‌پذیر باشد و مقسوم‌علیه دیگری نداشته باشد.
به‌عنوان مثال:

  • 2، 3، 5 و 7 عدد اول هستند.
  • 4، 6 و 9 عدد اول نیستند.

برای تشخیص عدد اول، می‌توان عدد موردنظر را بر اعداد کوچک‌تر یا مساوی خودش تقسیم کرد و تعداد مقسوم‌علیه‌های آن را بررسی نمود.

الگوریتم چیست؟

الگوریتم مجموعه‌ای از دستورالعمل‌های پشت سر هم و مرتب است که به رایانه داده می‌شود تا با اجرای آن‌ها، یک مسئله مشخص حل شود.
هر مسئله می‌تواند با الگوریتم‌های مختلفی حل شود، اما الگوریتمی مناسب‌تر است که ساده‌تر، سریع‌تر و بهینه‌تر باشد.

در این مقاله، از سه الگوریتم متفاوت برای پیاده‌سازی برنامه‌ی تشخیص عدد اول در پایتون استفاده می‌کنیم تا شما کاربرد الگوریتم در برنامه‌نویسی را بهتر درک کنید.

الگوریتم اول: روش شمارش مقسوم‌علیه‌ها

نکته: این الگوریتم ساده و قابل فهم است، اما از نظر سرعت بهینه نیست و بیشتر جنبه آموزشی دارد.

الگوریتم به این صورت عمل می‌کند:

  • یک عدد دریافت کن و آن را در متغیر number قرار بده.
  • یک متغیر شمارنده به نام accumulator تعریف کن و مقدار اولیه آن را 0 بگذار.
  • با یک شمارنده (i) از 1 تا number حرکت کن.
  • اگر number بر i بخش‌پذیر بود، مقدار accumulator را یک واحد افزایش بده.
  • مقدار i را یک واحد افزایش بده.
  • اگر مقدار i کوچک‌تر یا مساوی number بود، به مرحله 4 برگرد.
  • اگر مقدار accumulator برابر 2 بود، پیغام «عدد وارد شده عدد اول است» را نمایش بده.
  • در غیر این صورت، پیغام «عدد وارد شده عدد اول نیست» را نمایش بده.
  • اجرای الگوریتم را به پایان برسان.

پیاده‌سازی الگوریتم اول در پایتون

ابتدا عدد را از کاربر دریافت می‌کنیم و آن را به عدد صحیح تبدیل می‌کنیم. برای دریافت ورودی از کاربر، از دستور input() و برای تبدیل رشته به عدد صحیح از دستور int() استفاده می‌کنیم. عدد ورودی را در متغیر number قرار می‌دهیم. به این صورت:

number =int(input('please input your number: '))

سپس متغیر شمارنده مقسوم‌علیه‌ها را تعریف می‌کنیم و عدد 0 را به آن اختصاص می‌دهیم:

accumulator = 0

حال با استفاده از یک حلقه for، عدد ورودی را بر تمام اعداد از 1 تا خودش تقسیم می‌کنیم.

در حلقه، اگر باقیمانده‌ی تقسیم ورودی بر عدد جاری حلقه، برابر صفر بود یکی به متغیر accumulator اضافه می‌کنیم. به این صورت:

for i in range(1, number+1):
    if number % i == 0:
        accumulator +=1

وقتی حلقه‌ی ما به پایان می‌رسد، باید مقدار متغیر accumulator را بررسی کنیم. اگر مساوی 2 بود، پیغام "عدد اول است" و در غیر این صورت پیغام " عدد اول نیست" را چاپ می‌کنیم. برای این کار از دستور if-else استفاده می‌کنیم. به این صورت:

if accumulator == 2:
    print('your number is prime')  
else:
    print('your number is not prime')

ما به راحتی توانستیم با این الگوریتم ساده، برنامه‌ی پایتون تشخیص عدد اول را بنویسیم. همچنین برای دقت بیشتر، اعداد کوچک‌تر از 2 را به‌صورت جداگانه بررسی می‌کنیم:

number = int(input('Please enter a number: '))
if number < 2:
    print('Your number is not prime')
else:
    accumulator = 0
    for i in range(1, number + 1):
        if number % i == 0:
            accumulator += 1
    if accumulator == 2:
        print('Your number is prime')
    else:
        print('Your number is not prime')

الگوریتم دوم: استفاده از جمع‌کننده تعداد مقسوم‌علیه‌ها

در الگوریتم اول با استفاده از یک «جمع‌کننده تعداد مقسوم‌علیه‌ها» توانستیم تشخیص دهیم یک عدد اول است یا نه. حالا می‌خواهیم از روشی استفاده کنیم که نیازی به شمارش تعداد مقسوم‌علیه‌ها ندارد و به‌جای آن، فقط بررسی می‌کند آیا عدد ورودی مقسوم‌علیه‌ای غیر از ۱ و خودش دارد یا نه.

ایده اصلی: اگر عددی (بزرگ‌تر از ۱) حتی یک مقسوم‌علیه بین ۲ تا نصف خودش داشته باشد، «اول نیست».

مراحل الگوریتم

  • یک عدد بگیر و آن را در number قرار بده.
  • اگر number کوچک‌تر یا مساوی ۱ بود، پیام «عدد شما عدد اول نیست» را چاپ کن و پایان بده.
  • یک شمارنده به نام i انتخاب کن و مقدار ۲ را در آن قرار بده.
  • اگر باقیمانده تقسیم number بر i برابر ۰ بود، پیام «عدد شما عدد اول نیست» را چاپ کن و پایان بده.
  • مقدار i را یک واحد افزایش بده.
  • اگر i کوچک‌تر یا مساوی number / 2 بود، به مرحله ۴ برگرد.
  • اگر هیچ مقسوم‌علیه‌ای پیدا نشد، پیام «عدد شما عدد اول است» را چاپ کن.
  • پایان.

پیاده‌سازی الگوریتم دوم در پایتون

مثل قبل، ابتدا یک عدد صحیح از کاربر می‌گیریم و در متغیر number ذخیره می‌کنیم:

number = int( input('please input your number: '))

سپس با یک شرط ساده بررسی می‌کنیم که آیا عدد ورودی اصلاً «می‌تواند» اول باشد یا نه. (عددهای ۰ و ۱ اول نیستند.)

if number <= 1:
    print('your number is not prime')
else:
    # ادامه بررسی در این قسمت انجام می‌شود
    pass

اکنون وارد بخش اصلی می‌شویم. طبق الگوریتم، باید number را بر عددهای ۲ تا نصف خودش بررسی کنیم. بنابراین یک حلقه for می‌نویسیم:

for i in range(2, number // 2 + 1):
    if number % i == 0:
        print('your number is not prime')
        break

اگر حلقه بدون پیدا کردن مقسوم‌علیه تمام شود، یعنی عدد اول است. اینجا else مربوط به حلقه for است:

else:
    print('your number is prime')

اشکال‌زدایی کد

در این الگوریتم، هنگام وارد کردن عدد ۴، برنامه به‌اشتباه آن را عدد اول تشخیص می‌دهد. دلیل این مشکل، نحوه تعریف بازه حلقه for است، نه خود تقسیم بر ۲. در پایتون، تابع range حد بالایی را شامل نمی‌شود.
بنابراین در این خط:

for i in range(2, number // 2):

اگر number برابر ۴ باشد، مقدار number // 2 برابر ۲ می‌شود و در نتیجه حلقه به‌صورت زیر اجرا می‌شود:

range(2, 2)

این بازه خالی است و حلقه اصلاً اجرا نمی‌شود. به همین دلیل، برنامه مستقیماً وارد بخش else حلقه شده و عدد ۴ را به اشتباه «عدد اول» در نظر می‌گیرد.

برای جلوگیری از این مشکل، می‌توان بازه حلقه را طوری تعریف کرد که عدد ۲ نیز بررسی شود. کافی است حد بالای بازه را یک واحد افزایش دهیم:

for i in range(2, number // 2 + 1):

با این تغییر، برای عدد ۴، حلقه به‌درستی مقدار i = 2 را بررسی می‌کند و عدد ۴ به‌عنوان عدد اول شناسایی نخواهد شد.

کد اصلاح‌شده الگوریتم دوم

number = int(input('please input your number: '))
if number > 1:
    for i in range(2, number // 2 + 1):
        if number % i == 0:
            print('your number is not prime')
            break
    else:
        print('your number is prime')
else:
    print('your number is not prime')

نکته: الگوریتم دوم نسبت به الگوریتم اول بهینه‌تر است، زیرا به‌جای بررسی تمام اعداد تا خود number، فقط تا نصف آن بررسی انجام می‌دهد. هرچه الگوریتم بهینه‌تر باشد، سرعت اجرای برنامه بیشتر و مصرف منابع کمتر خواهد بود.

در ادامه مقاله، با الگوریتمی آشنا می‌شویم که از این هم بهینه‌تر است و در عمل، روش استاندارد تشخیص عدد اول محسوب می‌شود.

الگوریتم سوم: روش بهینه با بررسی تا جذر عدد

در الگوریتم سوم تشخیص عدد اول در پایتون، از روشی استفاده می‌کنیم که نسبت به دو الگوریتم قبلی بسیار بهینه‌تر و سریع‌تر است.
ایده اصلی این الگوریتم بر این اصل استوار است که برای تشخیص اول بودن یک عدد، نیازی نیست تمام مقسوم‌علیه‌ها بررسی شوند؛ کافی است بررسی را تا جذر عدد انجام دهیم.

مراحل الگوریتم

الگوریتم به‌صورت گام‌به‌گام به شکل زیر عمل می‌کند:

  • یک عدد دریافت کن و آن را در متغیر number قرار بده.
  • اگر number کوچک‌تر یا مساوی ۱ بود، عدد اول نیست.
  • اگر number کوچک‌تر یا مساوی ۳ بود، عدد اول است.
  • اگر number بر ۲ یا ۳ بخش‌پذیر بود، عدد اول نیست.
  • یک شمارنده به نام i تعریف کن و مقدار اولیه آن را ۵ قرار بده.
  • اگر number بر i یا i + 2 بخش‌پذیر بود، عدد اول نیست.
  • مقدار i را ۶ واحد افزایش بده.
  • اگر i × i کوچک‌تر یا مساوی number بود، به گام ۶ برگرد.
  • در غیر این صورت، عدد اول است.
  • اجرای الگوریتم پایان می‌یابد.

نکته مهم: بعد از بررسی ۲ و ۳، تنها اعدادی که به صورت 6k ± 1 هستند می‌توانند عدد اول باشند؛ به همین دلیل در هر تکرار، ۶ واحد به i اضافه می‌شود.

پیاده‌سازی الگوریتم سوم در پایتون

مانند الگوریتم‌های قبلی، ابتدا عدد را از کاربر دریافت می‌کنیم:

number = int( input('please input your number: '))

برای کنترل جریان اجرای برنامه و خروج در زمان مناسب، از یک حلقه while استفاده می‌کنیم که فقط یک‌بار اجرا می‌شود:

active = True
while active:
    pass

بررسی شرط‌های پایه: ابتدا ساده‌ترین حالت‌ها را بررسی می‌کنیم:

if number <= 1:
    print('Your number is not prime')
    break

اگر عدد بزرگ‌تر از ۱ باشد، شرط بعدی بررسی می‌شود:

if number <= 3:
    print('Your number is prime')
    break

با برقرار نبودن شرط دوم، سراغ شرط سوم می‌رویم. اگر عدد number بر 2 یا 3 بخش‌پذیر باشد (یعنی باقی‌مانده تقسیم صفر شود)، عدد اول نیست. در این حالت پیام مربوط چاپ می‌شود و با دستور break از حلقه خارج می‌شویم:

if  number % 2 == 0 or number % 3 == 0  : 
    print('your number is not prime')
    break

اکنون به گام 5 الگوریتم می‌رسیم. یک متغیر به نام i تعریف کرده و مقدار 5 را به آن اختصاص می‌دهیم. سپس یک حلقه while می‌نویسیم که تا زمانی که i*i کوچک‌تر یا مساوی number باشد ادامه پیدا کند (چون در این الگوریتم فقط تا جذر عدد بررسی می‌کنیم):

i = 5
while i * i <= number :
    pass

در این حلقه، اگر number بر i یا i+2 بخش‌پذیر باشد، عدد اول نیست. در این حالت پیام چاپ می‌شود و یک متغیر کمکی را False می‌کنیم تا بعد از خروج از حلقه، به اشتباه «prime» چاپ نشود. در غیر این صورت، مقدار i را 6 واحد زیاد می‌کنیم:

i = 5
is_prime = True
while i * i <= number:
    if number % i == 0 or number % (i + 2) == 0:
        print('your number is not prime')
        is_prime = False
        break
    i += 6اگر تا اینجا عدد «اول نیست» تشخیص داده نشده باشد، یعنی عدد اول است. برای پایان دادن به حلقه اصلی، مقدار active را False می‌کنیم و سپس پیام مناسب را چاپ می‌کنیم:

اگر تا اینجا عدد «اول نیست» تشخیص داده نشده باشد، یعنی عدد اول است. برای پایان دادن به حلقه اصلی، مقدار active را False می‌کنیم و سپس پیام مناسب را چاپ می‌کنیم:

active = False
print('your number is prime')  

در نهایت، کد کامل این الگوریتم به شکل زیر خواهد بود:

number = int(input('please input your number: '))
active = True
while active:
    if number <= 1:
        print('your number is not prime')
        break
    if number <= 3:
        print('your number is prime')
        break
    if number % 2 == 0 or number % 3 == 0:
        print('your number is not prime')
        break
    i = 5
    is_prime = True
    while i * i <= number:
        if number % i == 0 or number % (i + 2) == 0:
            print('your number is not prime')
            is_prime = False
            break
        i += 6
    active = False
    if is_prime:
        print('your number is prime')

نوشتن تابع تشخیص عدد اول

برای نوشتن یک تابع برای تشخیص اول بودن اعداد، می‌توانیم از هر سه الگوریتم بالا استفاده کنیم. اما ما ترجیح می‌دهیم از الگوریتم سوم استفاده کنیم زیرا بهینه‌تر است.

توضیحات کافی در خصوص هر سه الگوریتم در برنامه نویسی دادیم. فقط لازم است بدانید، خروجی تابع ما یک boolean است. اگر عدد ورودی، اول باشد، خروجی True و اگر عدد اول نباشد، خروجی False خواهد بود. کد تابع ما به این صورت خواهد بود:

def isPrime(n) : 
    if (n <= 1) : 
        return False
    if (n <= 3) : 
        return True
    if (n % 2 == 0 or n % 3 == 0) : 
        return False
    i = 5
    while (i * i <= n) : 
        if (n % i == 0 or n % (i + 2) == 0) : 
            return False
        i = i + 6
    return True
# ==================== end of function
number = int( input('please input your number: '))
if isPrime(number) : 
    print('your number is prime')  
else : 
    print('your number is not prime')  

چاپ اعداد ۱ تا ۱۰۰ به‌جز مضارب عدد ۴ در پایتون

در این تمرین، می‌خواهیم برنامه‌ای بنویسیم که تمام اعداد بین ۱ تا ۱۰۰ را چاپ کند، اما اگر عددی بر ۴ بخش‌پذیر بود (مضرب ۴ بود)، آن عدد در خروجی نمایش داده نشود.

این مثال تمرین بسیار خوبی برای یادگیری هم‌زمان موارد زیر است:

  • حلقه تکرار (for)
  • عملگر باقیمانده (%)
  • شرط (if)
  • مفهوم بخش‌پذیری در برنامه‌نویسی

تحلیل مسئله

صورت مسئله از ما سه چیز می‌خواهد:

  • تولید اعداد از ۱ تا ۱۰۰
  • بررسی بخش‌پذیر بودن هر عدد بر ۴
  • چاپ فقط عددهایی که بر ۴ بخش‌پذیر نیستند

برای بررسی بخش‌پذیری، از عملگر % استفاده می‌کنیم. اگر باقیمانده تقسیم یک عدد بر ۴ برابر صفر باشد، آن عدد مضرب ۴ است و نباید چاپ شود.

الگوریتم حل مسئله

الگوریتم به‌صورت مرحله‌به‌مرحله به شکل زیر است:

  • یک حلقه از ۱ تا ۱۰۰ ایجاد کن.
  • در هر تکرار، بررسی کن آیا عدد بر ۴ بخش‌پذیر است یا نه.
  • اگر عدد بر ۴ بخش‌پذیر نبود، آن را چاپ کن.
  • اگر بخش‌پذیر بود، از چاپ آن صرف‌نظر کن.

پیاده‌سازی در پایتون

کد برنامه به شکل زیر نوشته می‌شود:

for i in range(1, 101):
    if i % 4 != 0:
        print(i)

توضیح خط‌به‌خط کد

  • range(1, 101): اعداد ۱ تا ۱۰۰ را تولید می‌کند (عدد ۱۰۱ در نظر گرفته نمی‌شود).
  • i % 4 != 0: بررسی می‌کند که باقیمانده تقسیم عدد بر ۴ صفر نباشد؛ یعنی عدد مضرب ۴ نباشد.
  • print(i): فقط اعدادی را چاپ می‌کند که شرط بالا را داشته باشند.

نکته مهم: اگر شرط را به شکل زیر می‌نوشتیم:

if i % 4 == 0:
    continue

و سپس print(i) را خارج از شرط قرار می‌دادیم، نتیجه دقیقاً مشابه می‌شد.

جمع بندی

با نوشتن یک برنامه ی کاربردی پایتون، با سه الگوریتم و روش مختلف به شما نشان دادیم که یک برنامه نویس، چگونه باید تفکر الگوریتمی داشته باشد و چگونه یک الگوریتم را به کد تبدیل کند. تمامی الگوریتم‌ها در مقادیر کوچک، مشکل سرعت نخواهند داشت و این محاسبه اعداد بزرگ است که نشان می‌دهد آیا یک الگوریتم و برنامه ی پایتون بهینه شده است یا خیر؟ لذا شما در حین اینکه برنامه نویسی می‌آموزید، به سراغ یادگیری الگوریتم‌ها نیز بروید تا توانایی بهینه سازی برنامه هایتان را داشته باشید.

در قسمت بعدی این مجموعه مقالات نوشتن برنامه ی مقلوب یک عدد در پایتون، را به شما آموزش خواهیم داد. با ما همراه باشید.

اگر به یادگیری بیشتر در زمینه ی برنامه نویسی پایتون علاقه داری، یادگیری زبان پایتون بسیار ساده است. و با شرکت در دوره ی آموزش پایتون توسعه وب در آینده می‌تونی اپلیکیشن موبایل و دسکتاپ بسازی و وارد حوزه ی هوش مصنوعی هم شوی.

۶۵ دیدگاه
ما همه سوالات و دیدگاه‌ها رو می‌خونیم و پاسخ میدیم
فاطمه ۱۷ آبان ۱۴۰۲، ۱۵:۱۹

سلام وقت بخیر اگه بخایم از روش اولی که گذاشتید اعداد اول رو ابتدا از کاربر بگیره و اعداد اول قبل از اون عدد رو نمایش بده چجوری؟

نازنین کریمی مقدم ۲۳ آبان ۱۴۰۲، ۲۰:۳۷

درود میتونید از جواب تیک خورده تاپیک زیر استفاده کنید: https://stackoverflow.com/questions/27439898/printing-prime-numbers-up-to-a-users-input

Diyar ۲۱ آذر ۱۴۰۲، ۰۵:۴۱

اگه بخواهید کمک کنم شما رو

حنا ۰۷ مهر ۱۴۰۲، ۱۷:۰۶

سلام چرا چیزی ندارید که با شما ارتباط گرفت دوره پایتون دارید ؟

نازنین کریمی مقدم ۲۴ مهر ۱۴۰۲، ۰۵:۵۶

درود پایتون در حوزه‌های مختلف کاربرد داره و بهتره یک حوزه رو انتخاب کنید و در اون زمینه پایتون رو قوی کنید. ما سه دوره پایتون مقدماتی - پایتون وب و پایتون هوش مصنوعی داریم که از بخش دوره‌های آموزشی میتونید سرفصلهای هرکدوم رو ببینید. برای تماس با ما میتونید از راه‌های ارتباطی که در پایین صفحه قرار دادیم استفاده کنید.

Alireza Maleki ۰۷ مهر ۱۴۰۲، ۱۲:۴۲

سلام روزتون بخیر من متوجه نشدم که چرا در روش سوم در گام پنج به i مقدار 6 تا اضافه می‌کنیم؟

نازنین کریمی مقدم ۲۴ مهر ۱۴۰۲، ۱۱:۰۱

درود یکم پایینتر آقای مولایی درموردش در کامنتها توضیح دادند، بی زحمت همون رو مطالعه کنید که اطلاعات تکراری صفحه رو شلوغ نکنه.

علی عبداللهی ۰۶ مهر ۱۴۰۲، ۰۶:۵۴

درود الگوریتم سوم ایراد دارد برای ورودی 25 یا 55 نتیجه هم عدد اول و هم عدد غیر اول میدهد your number is not prime your number is prime الگوریتم صحیح به صورت زیر است. n = int(input('number: ')) flag = True if n <= 1: flag = False elif n <= 3: flag = True elif n % 2 == 0 or n % 3 == 0: flag = False else: i = 5 while i * i <= n: if n % i == 0 or n % (i + 2) == 0: flag = False break i += 6 if flag: print('prime') else: print('NOT prime')

نازنین کریمی مقدم ۲۴ مهر ۱۴۰۲، ۱۱:۰۳

درود بله حق باشماست. ممنون که با ما همراه هستید و به دوستان سون لرنی کمک میکنید.

۲۰ شهریور ۱۴۰۲، ۰۳:۵۳

تشکر

۰۸ مرداد ۱۴۰۲، ۱۰:۵۱

سلام امکانش هست داخل همین دستور بجای گرفتن عدد از کاربر خودمون با range نشون بدیم؟

نازنین کریمی مقدم ۱۵ مرداد ۱۴۰۲، ۱۰:۲۱

درود بله میشه. بستگی به سوال داره اگر گفته بود از کاربر دریافت کنه این کد وگرنه کد شما هم درست هست.

۲۳ اردیبهشت ۱۴۰۲، ۱۷:۱۵

امکانش هست اون سوال جمع اعداد اخر بعد از سوال پرسیدن اگر یس بود جمع ببنده؟کدش رو بنویسین

نازنین کریمی مقدم ۰۲ خرداد ۱۴۰۲، ۱۰:۰۲

درود یه نمونه کد در <a href="https://stackoverflow.com/questions/638048/how-do-i-sum-the-first-value-in-each-tuple-in-a-list-of-tuples-in-python" target="_blank" rel="noopener nofollow ugc">تاپیک جمع تاپلها</a> وجود داره میتونید از همون استفاده کنید.

۲۳ اردیبهشت ۱۴۰۲، ۰۵:۲۰

سلام ،من یه سوال داشتم و مدت هاست گیر کردم،،من فرض کنید ۳ تا لیست دارم،، (1,2,3),,,(5,7,9),,,(90,78,65) ,بعد میخوام بیام از کاربر مثلا سوال کنه با یس و نو،،اگه یس بود اعداد اخر هر مجموعه رو با هم جمع کنه،و اگر نو بودش اونو جمع نکنه،،چی کااااار کنم

نازنین کریمی مقدم ۲۳ اردیبهشت ۱۴۰۲، ۰۶:۳۰

درود فرآیند سوال کردنش که با یه اینپوت گرفتن از کاربر و چک کردنش اوکی میشه. اما برای جمع مقادیر باید اول هر لیست رو به یک عضو از آرایه numpy یا همون np.array تبدیل کنید و بعد با استفاده از حلقه خانه آخر هر یک رو جمع کنید.

۲۳ دی ۱۴۰۱، ۲۰:۵۳

من اینو خودم نوشتم x=2 print(&amp;#39;adad ra vared kon&amp;#39;) i=int(input()) while x&amp;lt;i: if i%x ==0: print(&amp;#39;aval nist&amp;#39;) print(x) break x+=1 continue if x==i: print(&amp;#39;aval ast&amp;#39;)

نازنین کریمی مقدم ۲۵ دی ۱۴۰۱، ۱۱:۱۸

متاسفانه چون فواصل در پایتون هست و اینجا بهم میریزه نمیتونم درستی کدتون رو تمام و کمال تایید کنم اما ممنون بابت اشتراک گذاری تلاش تون :)

۰۳ آذر ۱۴۰۱، ۰۶:۱۶

سلام . ببخشید ایا الگوریتمی وجود دارد که ورودی نداشته نباشد ؟ اگه وجود دارد میشه یک مثال بزنید .

نازنین کریمی مقدم ۰۵ آذر ۱۴۰۱، ۲۱:۱۷

درود اغلب الگوریتمها ورودی دارند اما بله امکانش هست. فرض کنید که سوال این باشه که دنباله اعداد اول یا اعداد زوج یا فیبوناچی و... رو چاپ کنید. اینجا ورودی ندارید و خودتون از یک شروع میکنید و پیش میرید.

۱۸ آبان ۱۴۰۱، ۱۹:۱۴

سلام اگر بخواییم برنامه ای بنویسیم که ،عددی وارد کنیم و تعداد اعداد اول قبلشو بهمون بگه چجوری باید نوشت؟

نازنین کریمی مقدم ۲۰ آبان ۱۴۰۱، ۱۴:۲۸

درود عدد وارد شده رو در یک متغیر بریزید. کافیه یک حلقه بنویسید که از 1 تا اون متغیر تکرار میشه. در بدنه حلقه هم کافیه یکی از الگوریتمهای بالا رو بذارید و هروقت عدد اولی رو تشخیص داد، به تعداد یکی اضافه کنه. درنهایت تعداد رو چاپ میکنید.

۰۹ آبان ۱۴۰۱، ۱۵:۴۲

من 13 سالمه و همینو خیلی ساده اینطوری حل کردم adad=int(input(&amp;quot;adad?&amp;quot;)) aadad=[] for i in range(1,adad+1): if adad%i==0: aadad.append(i) print(&amp;#39;inAdadBar&amp;#39;,aadad,&amp;#39;bakhshPazirAsr!!&amp;#39;) if len(aadad)==2: print(&amp;quot;adadAvalAst&amp;quot;) else : print(&amp;quot;adadMorakabAst&amp;quot;)

۲۱ شهریور ۱۴۰۱، ۱۲:۵۹

سلام ممنون میشم پاسخ بدین? برنامه ای بنویسید که ابتدا اعضای یک لیست را خوانده سپس از طریق نمایش یک منو و انتخاب گزینه ای توسط کاربر اعمال زیر را انجام دهد ۱)عضوی را به لیست اضافه میکند ۲)عضوی را در مکان خاص از لیست درج میکند ۳)اعضای لیست را مرتب میکند ۴)عضوی را از لیست حذف کند ۵)تعداد تکرار مقادیر را در لیست شمارش کند ۶)مکان یک مقدار را در لیست پیدا کند ۷) خروج

نازنین کریمی مقدم ۲۲ شهریور ۱۴۰۱، ۰۸:۲۱

درود بحث <a href="https://www.w3schools.com/python/python_lists.asp" target="_blank" rel="noopener nofollow ugc">لیست رو از سایت w3schools</a> پیش برید خوب توضیح داده.

۲۸ مرداد ۱۴۰۱، ۱۴:۰۳

روش نوشتن کد این چجوریه تعداد اعداد اول زیر ۱۰۰۰

نازنین کریمی مقدم ۲۹ مرداد ۱۴۰۱، ۰۷:۱۰

درود کافیه یک حلقه بنویسید که از 1 تا هزار تکرار میشه. در بدنه حلقه هم کافیه یکی از الگوریتمهای بالا رو بذارید و هروقت عدد اولی رو تشخیص داد، به تعداد یکی اضافه کنه. درنهایت تعداد رو چاپ میکنید.

علیرضا دهنوی ۲۵ مرداد ۱۴۰۱، ۰۷:۲۹

سلام وقت بخیر اگر عددی بگیریم و بخواییم کوچکترین عدداولی که تعداد رقم هاش با عدد ورودی یکیه بنویسید

نازنین کریمی مقدم ۲۶ مرداد ۱۴۰۱، ۰۴:۴۴

درود باید اول براساس تعداد ارقام یک شرط بگذاریم که اگر مثلا سه رقمی بود از 100، اگر دو رقمی بود از 10 و... شروع کنه. بعد در یک حلقه اعداد رو چک کنه تا به عدد اول برسه و اون رو چاپ کنه.

۲۳ مرداد ۱۴۰۱، ۱۱:۳۰

اگر بخوایم برنامه n عدد مشخص از کاربر بگیره و تعداد اعداد اولشون رو مشخص کنه ،چه جوری میشه این برنامه؟

نازنین کریمی مقدم ۲۴ مرداد ۱۴۰۱، ۰۵:۲۹

درود کافیه تعداد عدد مشخص رو از کاربر بگیرید و در یک متغیر بریزید، بعد یک حلقه بنویسید که شمارنده اش همون متغیری هست که درنظر گرفتید. در بدنه حلقه هم کافیه یکی از الگوریتمهای بالا رو بذارید.

۰۹ مرداد ۱۴۰۱، ۰۸:۳۷

روش سوم برای عدد 96998989 دچار باگ می‌شود ---- روش دوم خطای کمتری دارد

۰۲ مرداد ۱۴۰۱، ۲۰:۳۸

سلام میشه یه توضیحی در مورد for وrenge بدید و همچنین ارتباتشون

نازنین کریمی مقدم ۰۳ مرداد ۱۴۰۱، ۰۴:۱۳

درود حلقه for یک کار رو به تعداد مشخصی تکرار میکنه. یعنی مثلا در کد زیر عبارت سلام 10 بار اجرا میشه. <code> for n in range(10): print("سلام")</code> تابع range یک بازه از اعداد رو تولید میکنه که در مثال بالا 0 تا 10 هست. پیشنهاد میکنم به بخش <a href="https://7learn.com/course/programming-alphabet" rel="noopener" target="_blank">شروع برنامه نویسی</a> سر بزنید.

۱۴ تیر ۱۴۰۱، ۰۹:۰۷

وقت بخیر در برنامه تشخیص عدد اول هرزمان که سیستم عدد اول را تشخیص می‌دهد از برنامه خارج می‌شود. به عبارتی چطور می‌توان کدی داد که تا زمانی که متلا x را اعلام نکردم، دوباره سیستم از ما ورودی بخواهد

نازنین کریمی مقدم ۱۸ تیر ۱۴۰۱، ۰۶:۵۸

درود باید کل الگوریتم رو درون یک حلقه while بنویسید تا طبق شرط شما دائم اجرا بشه.

۱۹ خرداد ۱۴۰۱، ۱۹:۰۷

سلام اگه بگن تا زمانیکه کاربر عدد مثبت وارد میکند اعدار زوج کوچیکتر از آن را در خروجی نمایش بدهید این سوال چطور میشه حل کرد؟

نازنین کریمی مقدم ۲۰ خرداد ۱۴۰۱، ۰۰:۱۶

درود مراحل به این ترتیب هست: ۱. گرفتن ورودی و ذخیره در یک متغیر ۲. چک کردن اینکه مثبت هست یا نه. ۳. اگر مثبت بود در یک حلقه از یک تا اون عدد رو چاپ کنه. درغیر این صورت برنامه تموم بشه. ۴. برای اینکه تا زمانی که کاربر عدد مثبت وارد کرد این روند ادامه پیدا کنه، بهتره مراحل ۲ و ۳ داخل یک تابع نوشته بشه و به ازای هر ورودی فراخوانی بشه.

۰۹ اردیبهشت ۱۴۰۱، ۱۶:۰۳

عالیییی بود??✔?

۲۰ اسفند ۱۴۰۰، ۰۷:۵۴

سلام. الگوریتم سوم پیچیدگی زمانی کمتری نسبت به الگوریتمی که برای اعداد بزرگتر از یک، بخش پذیری از 2 تا مجذور +1 بررسی می‌کنه، داره؟!

نازنین کریمی مقدم ۲۱ اسفند ۱۴۰۰، ۱۱:۴۱

درود الگوریتم سوم عملا داره تا n/2 رو بررسی میکنه و نسبت به سایرین که تا n بررسی میکنند کمی بهینه‌تر هست، وگرنه از لحاظ تعریفی مرتبه اش همچنان مشابه با سایرین میشه.

۱۵ بهمن ۱۴۰۰، ۱۰:۱۶

اگه بخواهیم این اعداد رو با وایل خالی تشخیص بدیم چجوری میشه

نازنین کریمی مقدم ۱۶ بهمن ۱۴۰۰، ۰۹:۲۶

درود کافیه در الگوریتم اول بجای خطی که for داره، جمله while رو قرار بدید.

۲۸ دی ۱۴۰۰، ۱۲:۰۲

زیبا بود

۰۸ دی ۱۴۰۰، ۱۲:۳۲

برنامتون عالیه حق مطلب رو کاملا میرسونه ممنون از شما

۰۳ دی ۱۴۰۰، ۱۸:۰۰

سلام چطوری میتونم اعداد اول در یک حلقه رو بیابم ؟

نازنین کریمی مقدم ۰۴ دی ۱۴۰۰، ۰۶:۳۰

درود منظورتون اینه که اعداد اول یک بازه رو تشخیص بدیم، یا منظورتون اینه که تو الگوریتمش حتما از یک حلقه استفاده بشه؟

۱۹ آذر ۱۴۰۰، ۲۰:۲۴

مثلا بگن برنامه ای بنویسی که اعداد صحیح بین 10000تا100000را بیابید باید چطوری بنویسیم اون برنامه رو؟؟

نازنین کریمی مقدم ۲۰ آذر ۱۴۰۰، ۰۵:۴۷

سلام برای این کار کافیه از حلقه استفاده کنید: <code>for i in range(10000,100001): print(i)</code>

ali ۱۰ آذر ۱۴۰۰، ۱۶:۳۵

ممنون از شما جالبته وقتی عدد 25 به برنامه میدی خروجی هم Prime پرینت میشه و هم not prime اما برای اعداد دیگر اینجور نیست!!!!

Nazanin KarimiMoghaddam ۱۳ آذر ۱۴۰۰، ۰۶:۲۴

درود کدوم الگوریتم تون اینطوری هست؟ چون من الگوریتم آخر رو تست میکنم چنین مشکلی نداره

۲۳ آذر ۱۴۰۰، ۰۵:۲۵

کد بالای کد آخر اون که فانکشن نیست! number = int(input(&amp;#39;please input your number: &amp;#39;)) active = True while active: if number &amp;lt;= 1: print(&amp;#39;your number is not prime&amp;#39;) break if number &amp;lt;= 3: print(&amp;#39;your number is prime&amp;#39;) break if number % 2 == 0 or number % 3 == 0: print(&amp;#39;your number is not prime&amp;#39;) break i = 5 while i * i &amp;lt;= number: if number % i == 0 or number % (i + 2) == 0: print(&amp;#39;your number is not prime&amp;#39;) break i = i + 6 active = False print(&amp;#39;your number is prime&amp;#39;)

مهدی ۰۱ آذر ۱۴۰۰، ۱۴:۵۹

سلام لطفا تشخیص عدد اول به روش حلقه‌های تودرتو بذارید

Nazanin KarimiMoghaddam ۰۳ آذر ۱۴۰۰، ۰۶:۰۶

درود برای اینکه دوباره کاری نشه، بی زحمت پاسخ تیک خورده از<a href="https://stackoverflow.com/questions/22007492/prime-number-python-nested-loops" target="_blank" rel="noopener nofollow ugc"> این لینک</a> رو مطالعه کنید. جواب سوالتون رو کامل میده.

بهراد تاجیک ۲۲ آبان ۱۴۰۰، ۱۰:۲۹

سلام خسته نباشید. میتونید بگید ما همین اول بودن یا نبودن رو چه جوری میتونیم با تابع بازگشتی بنویسیم؟

Nazanin KarimiMoghaddam ۲۲ آبان ۱۴۰۰، ۱۰:۴۴

درود پاسخهای <a href="https://stackoverflow.com/questions/37095508/how-do-i-find-a-prime-number-using-recursion-in-python" target="_blank" rel="noopener nofollow ugc">این لینک</a> استک رو ببینید جوابتون رو به طور کامل میگیرید.

فربد ۲۵ مهر ۱۴۰۰، ۱۰:۱۴

سلام یک مشکلی هست اونم اینه که عدد 1 رو میدیم میگه اول نیست و اگه میشه این مشکل رو بر طرف کنید.

نازنین کریمی مقدم ۲۶ مهر ۱۴۰۰، ۰۰:۰۸

درود برای اینه که عدد یک اول نیست واقعا، در ریاضیات کوچکترین عدد اول 2 هست.

pouriya ۲۳ بهمن ۱۳۹۹، ۱۷:۵۵

الگوریتم دوم باگ داره 4 رو بهش میدی پرایم میاره من دیباگش کردم الان درستش اینه: [code] number = int(input('')) while number % 2 == 0: if number % 2 == 0: print ('not prime') break else: if number &gt; 1: for i in range(2 , number//2): if number % i == 0: print('not prime') break else: print('prime') else: print('not prime') [/code]

عبدالرضا مولایی ۲۶ بهمن ۱۳۹۹، ۰۶:۳۵

سلام دوست عزیز، خوشحالیم که با دقت آموزش‌های ما را دنبال می‌کنید. در الگوریتم دوم به دلیل اینکه ما عدد ورودی را بر 2 تقسیم می‌کنیم، عدد 4 تبدیل به 2 شده و به اشتباه آن را یک عدد اول تشخیص می‌دهد. برای جلوگیری از این مشکل برای اولین راه حل کافی است یک شرط قبل از حلقه‌ی for نوشته تا عدد 4 وارد حلقه نشود. به این طریق باگ موجود بر طرف میشود. البته یک راه حل ساده‌تر نیز وجود دارد که در متن اصلی قرار دادم. راه حل اول به این صورت است: [code] if number == 4: print('your number is not prime') else: for i in range(2 , number//2): [/code]

میثم نصرتی آذر ۲۵ آبان ۱۳۹۹، ۱۰:۱۱

با سلام ببخشید راستش من این الگوریتم سوم رو مخصوصا اونجا که i = i + 6 کرده رو متوجه نشدم ، امکانش هست بیشتر توضیح بدید؟

عبدالرضا مولایی ۲۶ آبان ۱۳۹۹، ۰۷:۰۶

سلام دوست عزیز، در این الگوریتم به جای اینکه عدد مورد نظر را بر تمامی اعداد قبل خودش تقسیم کنیم، ابتدا آن را بر 2 و 3 تقسیم می‌کنیم اگر بخش پذیر بود خیلی راحت متوجه می‌شویم که عدد اول نیست و اگر بخش‌پذیر نبود آن بر اعداد 5 و 7 تقسیم می‌کنیم و باز اگر بخش پذیر بود عدد ما اول نیست و در غیر این صورت i خود را که 5 باشد با 6 جمع می‌کنیم (i = i+6) و دوباره مرحله قبل را که بر 5 و 7 بود را این مرتبه با 11 و 13 امتحان می‌کنیم.. و این کار را ادامه می‌دهیم تا وقتی که i*i بزرگتر مساوی عدد مورد نظرمان شود. اگر هیچکدام از این شرایط برقرار نشد پیغام عدد ما اول است را چاپ می‌کنیم. امیدوارم الان بهتر متوجه شده باشید.

harez ۰۶ مرداد ۱۳۹۹، ۱۱:۳۷

الگوریتم دوم باگ داره 4 رو بدی بهش prime میده

J.m ۰۶ اردیبهشت ۱۳۹۹، ۰۵:۲۷

سلام , اقا زحمت کشیدید , ولی بهتر نبود کد هاتون رو اول تست میکردید بعد مینوشتید . چون خیلی اشتباه نوشته شده , مثلا در الگوریتم دوم که در اخر که کد‌ها رو کامل نوشتید ایندنت else زیر for نوشته شده , باید زیر if باشد . اشکال دیگر اینکه جلوی کلمه break پرانتز گذاشتید!!

عبدالرضا مولایی ۰۶ اردیبهشت ۱۳۹۹، ۰۹:۵۷

سلام دوست عزیز، تمامی کدها تست شده است.. درمورد else در for این از ویژگی‌های زبان پایتون است اگر قصد آشنایی بیشتر در این مورد را دارید از این لینک استفاده کنید: https://book.pythontips.com/en/latest/for_-_else.html درمورد پرانتز در break نیز در یک مورد، اشتباه تایپی رخ داده. ممنون از اینکه اطلاع دادید.

دوره الفبای برنامه نویسی با هدف انتخاب زبان برنامه نویسی مناسب برای شما و پاسخگویی به سوالات متداول در شروع یادگیری موقتا رایگان شد:

۲۰۰ هزار تومان رایگان
دریافت دوره الفبای برنامه نویسی