Viết hàm trả về số lượng từ vừa chứa ký tự, vừa chứa chữ số trong chuỗi s.
Bài tập Python tự luyện

Danh sách bài học
Viết hàm trả về số lượng từ vừa chứa ký tự, vừa chứa chữ số trong chuỗi s.
Bài toán cần xử lý
Viết hàm với tham số truyền vào là chuỗi s. Trả về số lượng từ vừa chứa ký tự, vừa chứa chữ số trong chuỗi s.
Kiến thức cần có
- Hàm input() và hàm print()
- Biến và kiểu dữ liệu
- Cấu trúc lặp trong Python
- Cấu trúc rẽ nhánh trong Python
- Hàm trong Python
- Các phương thức xử lý chuỗi trong Python
- split()
- isdigit()
- isalpha()
Định dạng đầu vào
Gồm một dòng duy nhất chứa chuỗi bất kỳ.
Định dạng đầu ra
Gồm một dòng duy nhất hiển thị kết quả theo đề bài yêu cầu
Ví dụ
- Input 1:
Kteam1 kteam k2team
- Output 1:
2
- Input 2:
#nothing
- Output 2:
0
- Input 3:
--Kteam-- **1** _K2_Team
- Output 3:
1
Gợi ý
- Định nghĩa hàm dem_tu với tham số là chuỗi s:
- Khởi tạo biến đếm bằng 0 để đếm các từ thỏa yêu cầu đề bài
- Sử dụng phương thức split() để lấy danh sách các từ trong chuỗi s
- Sử dụng vòng lặp for để duyệt qua các từ trong chuỗi s:
- Sử dụng 2 biến làm biến đánh dấu chữ số và ký tự. Gán giá trị khởi đầu là False
- Sử dụng vòng lặp for để duyệt các ký tự trong từng từ:
- Sử dụng phương thức isalpha() và isdigit() để kiểm tra từng ký tự
- Thay đổi biến đánh dấu thành True nếu kiểm tra đúng
- Nếu cả 2 biến đánh dấu đều ở giá trị True tức là từ thỏa yêu cầu đề bài. Tăng biến đếm.
- Trả về giá trị biến đếm cho hàm
- Dùng hàm input() để nhập hai chuỗi từ bàn phím.
- Gọi hàm dem_tu và truyền vào các tham số cần thiết.
- Dùng hàm print() hiển thị kết quả theo định dạng đầu ra yêu cầu.
Code mẫu
def dem_tu(s):
dem = 0
#Su dung phuong thuc split() de cat chuoi s thanh cac tu ngan cach bang khoang trang
dsCacTu = s.split()
#Su dung vong lap for de duyet cac tu trong danh sach cac tu cua chuoi s
for tu in dsCacTu:
coKyTu = False
coChuSo = False
#Duyet cac ky tu trong tu
for kyTu in tu:
#Kiem tra ky tu
if kyTu.isalpha():
coKyTu = True
#Kiem tra chu so
if kyTu.isdigit():
coChuSo = True
#Neu tu vua chua ky tu vua chua chu so thi tang bien dem
if coKyTu and coChuSo:
dem += 1
return dem
#Nhap gia tri tu ban phim
s = input()
#Goi ham va truyen cac tham so can thiet
print(dem_tu(s))
Kết luận
Trong bài này, Kteam đã hướng dẫn bạn cách viết hàm với tham số truyền vào là chuỗi s. Trả về số lượng từ vừa chứa ký tự, vừa chứa chữ số trong chuỗi s. 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 TRẢ VỀ LIST SỐ TỰ NHIÊN VÀ LIST BÌNH PHƯƠNG CÁC SỐ TỰ NHIÊN NHỎ HƠN N (VỚI N LÀ THAM SỐ TỰ NHIÊN).
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 trả về số lượng từ vừa chứa ký tự, vừa chứa chữ số trong chuỗi s. 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 like và share để ủng hộ Kteam và tác giả nhé!

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ê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.
Nội dung bài viết
Khóa học
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ểu và thự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ó"
def find_(s):
s = s.split()
count = 0
for char in s:
a, b = 0, 0
for value in char:
if value.isupper() or value.islower():
a += 1
elif value.isdigit():
b += 1
if a > 0 and b > 0:
count += 1
return count
print(find_(s=input()))
def func(s):
s = s.split()
check = 0
occur = 0
for st in s:
for c in st:
if c.isdigit():
check += 1
break
for c in st:
if c.isalpha():
check += 1
break
if check == 2: occur += 1
check = 0
return occur
s = input("Nhập 1 chuỗi: ")
print(func(s))
def ketqua(a):
a=a.split()
Dem=0
for tu in a:
Demtu=Demso=0
for i in tu:
if i.isdigit():
Demso=Demso+1
elif i.isalpha():
Demtu=Demtu+1
if Demso>0 and Demtu>0:
Dem=Dem+1
return Dem
a=input("Nhập chuỗi: ")
print(ketqua(a))