Hàm trả về từ có độ dài lớn nhất theo thứ tự trong chuỗi s. (Tham số truyền vào là chuỗi s).

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

5.0 (3 đánh giá)
Tạo bởi Kteam Cập nhật lần cuối 23:44 11-11-2021 17.465 lượt xem 12 bình luận
Tác giả/Dịch giả: TrongPhuCBL49 Kteam
Học nhanh

Danh sách bài học

Hàm trả về từ có độ dài lớn nhất theo thứ tự trong chuỗi s. (Tham số truyền vào là chuỗi s).

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

Viết hàm trả về từ có độ dài lớn nhất trong chuỗi s. Với tham số truyền vào là chuỗi s. Nếu có nhiều từ có độ dài bằng nhau thì trả về từ có thứ tự nhỏ hơn (sắp xếp theo bảng chữ cái).


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()
  • So sánh chuỗi

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

Gồm một dòng chứa chuỗi bất kỳ.


Định dạng đầu ra

Gồm một dòng duy nhất hiển thị chuỗi kết quả theo yêu cầu đề bài.


Ví dụ

  • Input 1:
Kteam education - free
  • Output 1:
education

  • Input 2:
Kteam xin chao
  • Output 2:
chao

  • Input 3:
Kteam --xin-- chao
  • Output 3:
--xin--

Gợi ý

  • Định nghĩa hàm tu_dai_nhat với tham số là chuỗi s:
  • Sử dụng một biến lưu từ dài nhất. Ban đầu gán bằng chuỗi rỗng
  • 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:
    • So sánh độ dài từng từ với độ dài từ dài nhất.
      • Nếu độ dài lớn hơn thì gán từ dài nhất bằng từ đang xét.
      • Nếu độ dài bằng nhau thì so sánh theo thứ tự bảng chữ cái.
  • Trả về từ dài nhất
  • Dùng hàm input() để nhập hai chuỗi từ bàn phím.
  • Gọi hàm tu_dai_nhat 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 tu_dai_nhat(s):
   #Bien luu tu dai nhat
   tuDaiNhat = ""
   #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:
       #So sanh do dai cac tu voi do dai tuDaiNhat hien tai
       #Neu do dai bang voi tuDaiNhat thi so sanh theo thu tu bang chu cai
       if (len(tu) > len(tuDaiNhat)) or (len(tu) == len(tuDaiNhat) and tu < tuDaiNhat):
           tuDaiNhat = tu
      
   return tuDaiNhat

#Nhap gia tri tu ban phim
s = input()

#Goi ham va truyen cac tham so can thiet
print(tu_dai_nhat(s))

Kết luận

Trong bài này, Kteam đã hướng dẫn bạn cách viết hàm trả về từ có độ dài lớn nhất trong chuỗi s. Với tham số truyền vào là chuỗi s. Nếu có nhiều từ có độ dài bằng nhau thì trả về từ có thứ tự nhỏ hơn (sắp xếp theo bảng chữ cái).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Ị CÁC CÂU CỦA CHUỖI S. CÁC CÂU ĐÃ XÓA KHOẢNG TRẮNG THỪA VÀ ĐỊNH DẠNG THEO TITTLE().

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 Hàm trả về từ có độ dài lớn nhất theo thứ tự trong chuỗi s. (Tham số truyền vào là 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 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ê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

Tác giả/Dịch giả

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.


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á

AnonyN đã đánh giá 16:31 27-09-2021

TankAnk đã đánh giá 16:11 04-09-2021

Mai Anh Tài đã đánh giá 19:50 23-08-2021

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
haikhongbeo993 đã bình luận 00:27 28-10-2024

def larger_s(s:str):

    string = s.split()

    big_len= 0

    big_s = "None"

    for value in string:

        if len(value) > big_len:

            big_len= len(value)

            big_s = value

        elif len(value) == big_len:

            if value < big_s:

                big_s = value

            else:

                continue

    return big_s

 

print(larger_s(s="hai hoi beo"))

kakavan đã bình luận 16:58 02-06-2024

def longest(s):
    s = s.split()
    longest_word = ""

    for w in s:
        if len(w) > len(longest_word):
            longest_word = w
        elif len(w) == len(longest_word) and w < longest_word:
            longest_word = w

    return longest_word

s = input("Nhập 1 chuỗi: ")

print(longest(s))

TayMonKhanh đã bình luận 08:19 02-07-2023

def Ketqua(a):

    a=a.split()

    Tong=""

    for chu in a:

        if len(chu)>len(Tong) or len(chu)==len(Tong) and chu<Tong:

            Tong=chu

    return Tong

#Khung

a=input("Nhập chuỗi: ")

print(Ketqua(a))

NhuwLikesVeggies đã bình luận 10:14 18-07-2022
def longest_string(s):
    longest = s.split()[0]
    for string in s.split():
        if len(string) >= len(longest):
            if string < longest:
                longest = string
    return longest
s = input()
print(longest_string(s))

 

ntnhan.0705 đã bình luận 23:04 06-10-2021
def dai_nhat (s):
    daiNhat = ''
    for i in s:
        if len(i) > len(daiNhat):
            daiNhat = i
    return daiNhat
s = input('Nhập chuỗi: ').split()        
print(dai_nhat(s)) 

 

Không có video.