Viết Hàm Liệt Kê Các Số Hoàn Thiện Nhỏ Hơn N. | How Kteam

Đăng ký Đăng nhập
  • PG Pages
  • Khóa học
    • Lập trình
      • Lập trình C# .Net
      • Lập trình C++
      • Lập trình Android
      • Điều trường học không dạy
      • Thủ thuật lập trình
      • Lập trình Java
      • Unity3D
      • Phân tích thiết kế
      • Lập trình Python
      • Lập trình PHP
      • JavaScript - (Website)
      • Lập trình Front-End
      • Lập trình Mobile
    • Microsoft Office 2016
      • Microsoft Word 2016
      • Microsoft Excel 2016
      • Microsoft PowerPoint 2016
    • IT & Phần mềm
      • Thủ thuật máy tính
      • Hướng dẫn cài đặt
      • Bảo mật máy tính
      • Phần cứng & Bảo mật
    • Đồ họa hình ảnh
      • Adobe Photoshop LightRoom
    • Kinh tế
      • Quản trị kinh doanh
      • Kế toán
      • Nhân sự
      • SEO
      • Marketing
    • Ngoại ngữ
      • Tiếng anh
    • Kỹ năng mềm
      • Kỹ năng mềm
    • Tin tức
      • Tin tức công nghệ
  • Khóa học
  • Hỏi đáp
  • Bài viết
  • Tag
  • Kter
  • Về Kteam
  • Tài trợ
  • Phản hồi
Viết hàm liệt kê các số hoàn thiện nhỏ hơn n.

Bài tập Python tự luyện

5.0 (1 đánh giá) Tạo bởi Kteam Cập nhật lần cuối 23:40 11-11-2021 20.368 lượt xem 14 bình luận Tác giả/Dịch giả: TrongPhuCBL49 Kteam Học nhanh Khóa học Lập trình Lập trình Python Bài tập Python tự luyện Viết hàm liệt kê các số hoàn thiện nhỏ hơn n.

Danh sách bài học

Viết hàm liệt kê các số hoàn thiện nhỏ hơn n.

Bài tập Python tự luyện Tạo bởi Kteam 20.368 14 Học nhanh

Viết hàm liệt kê các số hoàn thiện nhỏ hơn n.

Nội dung bài viết Học nhanh

Bài trước Bài sau

Bài toán cần xử lý

Viết hàmliệt kê các số hoàn thiện nhỏ hơn n (Có gọi hàm kiểm tra số hoàn thiện). Với tham số tự nhiên n.

Kiến thức cần có

  • Hàm input() và hàm print()
  • Cấu trúc lặp trong Python
  • Cấu trúc rẽ nhánh trong Python
  • Biến và kiểu dữ liệu
  • Hàm trong Python
  • Xử lý ngoại lệ (Exception Handling)

Định dạng đầu vào

  • Gồm một dòng duy nhất chứa số tự nhiên n

Định dạng đầu ra

Gồm một dòng duy nhất hiển thị các số hoàn thiện nhỏ hơn n. Các số cách nhau một khoảng trắng.

Lưu ý: Nếu n nhỏ hơn 0 thì xuất thông báo: Vui long nhap so tu nhien!

Nếu input nằm ngoài định dạng đầu vào thì xuất thông báo: Dinh dang dau vao khong hop le!

Ví dụ

  • Input 1:
5
  • Output 1:
#nothing
  • Input 2:
1000
  • Output 2:
6 28 496
  • Input 3:
-1457
  • Output 3:
Vui long nhap so tu nhien!
  • Input 4:
Kteam
  • Output 4:
Dinh dang dau vao khong hop le!

Gợi ý

  • Định nghĩa hàm kiem_tra_so_hoan_thien với tham số là số tự nhiên n
  • Tham khảo thuật toán kiểm tra số hoàn thiện ở Bài 3.15
  • Trả về True nếu là số nguyên tố. Trả về False nếu không là số nguyên tố
  • Định nghĩa hàm liet_ke_so_hoan_thien với tham số là số tự nhiên n:
  • Sử dụng vòng lặp for để duyệt các số nhỏ hơn n:
    • Với mỗi số được duyệt qua, gọi hàm kiem_tra_so_hoan_thien
    • Nếu là số hoàn thiện thì dùng hàm print() kết hợp với tham số end để hiển thị kết quả theo định dạng đầu ra yêu cầu
  • Sử dụng cấu trúc Xử lý ngoại lệ để xử lý các trường hợp gây ra lỗi
  • Đặt toàn bộ chương trình trong khối try.
  • Dùng hàm input() để nhập giá trị n từ bàn phím.
  • Chuyển giá trị n mới nhận được sang kiểu số nguyên, vì các giá trị nhận được từ hàm input() mặc định sẽ ở kiểu chuỗi.
  • Sử dụng cấu trúc rẽ nhánh để xử lý trường hợp n âm. Hiển thị thông báo nếu có.
  • Gọi hàm liet_ke_so_hoan_thien và truyền vào tham số n.
  • Lỗi sẽ phát sinh ở lệnh ép kiểu nếu định dạng đầu vào không hợp lệ. Dùng lệnh except để bắt lỗi:
  • Dùng hàm print() hiển thị thông báo lỗi ra màn hình

Code mẫu

def kiem_tra_so_hoan_thien(n): tongCacUoc = 0 #Su dung vong lap for de duyet cac so tu 1 den n // 2 + 1 for i in range(1, n // 2 + 1): #Kiem tra tinh chia het if n % i == 0: #Tinh tong cac uoc tongCacUoc += i if n == tongCacUoc: return True return False def liet_ke_so_hoan_thien(n): for i in range(1, n): if kiem_tra_so_hoan_thien(i): print(i, end=' ') #Khoi lenh co the phat sinh loi try: #Nhap gia tri tu ban phim #Ep kieu du lieu sang so nguyen n = int(input()) #Su dung cau truc re nhanh xu ly truong hop n < 0 if n < 0: print("Vui long nhap so tu nhien!") else: liet_ke_so_hoan_thien(n) #Khoi lenh duoc thuc thi khi loi xay ra except: print("Dinh dang dau vao khong hop le!")

Kết luận

Trong bài này, Kteam đã hướng dẫn bạn cách viết hàm liệt kê các số hoàn thiện nhỏ hơn n (Có gọi hàm kiểm tra số hoàn thiện). Với tham số tự nhiên n.Thêm bài giải của bạn vào phần bình luận để được Kteam review code và fix lỗi (nếu có) trong livestream của khóa học này.

Ở bài tiếp theo, chúng ta sẽ cũng nhau học cách VIẾT HÀM HIỂN THỊ ĐỘ DÀI CHUỖI VÀ HIỂN THỊ CHUỖI RA MÀN HÌNH. (THAM SỐ LÀ CHUỖI S).

Cảm ơn các bạn đã theo dõi bài viết. Hãy để lại bình luận hoặc góp ý của bạn để phát triển bài viết tốt hơn. Đừng quên " Luyện tập - Thử Thách - Không ngại khó!"

Tải xuống

Tài liệu

Nhằm phục vụ mục đích học tập Offline của cộng đồng, Kteam hỗ trợ tính năng lưu trữ nội dung bài học Viết hàm liệt kê các số hoàn thiện nhỏ hơn n. dưới dạng file PDF trong link bên dưới.

Ngoài ra, bạn cũng có thể tìm thấy các tài liệu được đóng góp từ cộng đồng ở mục TÀI LIỆU trên thư viện Howkteam.com

Đừng quên likeshare để ủng hộ Kteam và tác giả nhé!

Project

Nếu việc thực hành theo hướng dẫn không diễn ra suôn sẻ như mong muốn. Bạn cũng có thể tải xuống PROJECT THAM KHẢO ở link bên dưới!

Thảo luận

Nếu bạn có bất kỳ khó khăn hay thắc mắc gì về khóa học, đừng ngần ngại đặt câu hỏi trong phần BÌNH LUẬN bên dưới hoặc trong mục HỎI & ĐÁP trên thư viện Howkteam.com để nhận được sự hỗ trợ từ cộng đồng.

CỘNG ĐỒNG HỎI ĐÁP HOWKTEAM.COM GROUP THẢO LUẬN FACEBOOK

Nội dung bài viết

Tác giả/Dịch giả

TrongPhuCBL49

Có niềm đam mê với thuật toán và tư duy logic. Là người cầu toàn, thích lập kế hoạch và tối ưu mọi vấn đề trong cuộc sống. Mong muốn luôn sống vui vẻ yêu đời =))) không bon chen.

Sở thích cá nhân: Đàn ca nhảy múa và đi du lịch.

Kteam

Khóa học

Bài tập Python tự luyện

Serial dành cho những bạn cần luyện tập phương pháp, tu duy lập trình. Làm quen với các bài toán trong lập trình, ngẫu nhiên từ cơ bản đến nâng cao. Nội dung Serial này được phân tách chi tiết nhất có thể, nhằm giúp các bạn dễ hiểuthực hành được ngay.

Bạn nên tự làm lại từng bài tập trên video để có kết quả tốt nhất. Cùng Kteam "Luyện tập - Thử thách - không ngại khó"

Đánh giá

TankAnk đã đánh giá 07:46 27-08-2021 Báo cáo

Bình luận

Để bình luận, bạn cần đăng nhập bằng tài khoản Howkteam.

Đăng nhập dinhvanbao đã bình luận 17:57 05-12-2024

hehehe

0 0 Trả lời Báo cáo haikhongbeo993 đã bình luận 23:56 26-10-2024

def completion_number(number):

count = 0

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

if number % i == 0:

count += i

return count

def lst_comp_number(n):

for j in range(1, n):

if completion_number(j) == j:

print(j, end=' ')

# Trong trường hợp muốn kiểm tra số hoàn thiện trong khoảng a-b:

if not completion_number(j) == j:

print("no completion number")

try:

n = int(input("input random number: "))

if n < 0:

print("input a number larger 0")

else:

lst_comp_number(n)

except ValueError:

print("input value error")

0 0 Trả lời Báo cáo kakavan đã bình luận 09:42 01-06-2024

def pernocheck(num): if num < 2: return False

total = 0 for i in range(1,int(num//2)+1): if num % i == 0: total += i

if num == total: return True return False

def pernoprint(n): for i in range(n): if pernocheck(i) == True: print(i,end=' ')

while True: try: n = int(input("Nhập 1 số: "))

if n < 0: print("Vui lòng nhập số tự nhiên!") else: pernoprint(n) break except: print("Định dạng đầu vào không hợp lệ!")

0 0 Trả lời Báo cáo Bikeys đã bình luận 07:41 17-02-2024

try:

n = int(input(' input number n : '))

def divisor_num (divisor):

lst_divisor_num = []

for i in range (1,divisor):

if divisor % i == 0 :

lst_divisor_num.append(i)

return sum(lst_divisor_num)

def perfect_num(n):

lst=[]

for i in range (1,n):

if i == divisor_num(i):

print(i,end=' ')

if n < 0:

print('vui long nhap so tu nhien')

else:

perfect_num(n)

except:

print('Dinh dang dau vao khong hop le')

0 0 Trả lời Báo cáo TayMonKhanh đã bình luận 04:26 01-07-2023

def Kiem_tra_n(n):

if Tong_uoc(n)==n:

print(n,end=" ")

def Tong_uoc(n):

tong=0

for i in range(1,n):

if n%i==0:

tong=tong+i

return tong

#Khung

try:

a=int(input("Nhập số n: "))

if a<0:

print("Vui lòng nhập số tự nhiên")

else:

for n in range(1,a):

Kiem_tra_n(n)

except:

print("Định dạng kh hợp lệ")

0 0 Trả lời Báo cáo Xem thêm ...
Danh sách bài giảng
Nội dung
Không có video.
Danh sách bài giảng

Đánh giá và Nhận xét

Quan tâm Tag theo dõi

Yêu cầu đăng nhập

Để sử dụng tính năng này, Bạn cần đăng nhập bằng tài khoản Howkteam.

Đăng nhập

AD BLOCKER DETECTED

Để xem được nội dung và giúp Kteam duy trì hoạt động. Bạn vui lòng tắt Adblock trên website howkteam.vn nhé!

Từ khóa » Tìm Số Hoàn Hảo Trong Python