1. Trang chủ
  2. » Giáo Dục - Đào Tạo

(Skkn rất hay) xây dựng một số bài tập về kiểu dữ liệu danh sách và xâu kí tự nhằm hỗ trợ phát triển phẩm chất và năng lực học sinh lớp 10 học lập trình bằng ngôn ngữ python

48 1 0

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 48
Dung lượng 2,06 MB

Nội dung

SỞ GIÁO DỤC VÀ ĐÀO TẠO NGHỆ AN TRƯỜNG THPT TÂN KỲ  SÁNG KIẾN KINH NGHIỆM ĐỀ TÀI: sk kn XÂY DỰNG MỘT SỐ BÀI TẬP VỀ KIỂU DỮ LIỆU DANH SÁCH VÀ XÂU KÍ TỰ NHẰM HỖ TRỢ PHÁT TRIỂN PHẨM CHẤT VÀ NĂNG LỰC HỌC SINH LỚP 10 HỌC LẬP TRÌNH BẰNG NGƠN NGỮ PYTHON Lĩnh vực: Tin học Tác giả: Phan Xuân Thường Tổ chuyên mơn: Tốn- Tin Số điện thoại: 0916929867 Năm học: 2022 - 2023 MỤC LỤC PHẦN I ĐẶT VẤN ĐỀ Lý chọn đề tài 2 Mục đích nghiên cứu Đối tượng nghiên cứu Phương pháp nghiên cứu Tính đề tài PHẦN II NỘI DUNG NGHIÊN CỨU Cơ sở lý thuyết Cơ sở thực tiễn Giải pháp 3.1 Bài tập kiểu liệu danh sách 3.1.1 Một số tập 3.1.2 Một số tập nâng cao 14 3.2 Bài tập kiểu liệu xâu kí tự 25 kn sk 3.2.1 Một số tập 25 3.2.2 Một số tập nâng cao 31 Khảo sát cấp thiết tính khả thi giải pháp đề xuất 39 Nhận xét kết sau thực đề tài 43 PHẦN III KẾT LUẬN 46 Về mặt lý thuyết thực tiễn 46 Phạm vi áp dụng, hạn chế, hướng phát triển kiến nghị 46 TÀI LIỆU THAM KHẢO 47 PHẦN I ĐẶT VẤN ĐỀ Lý chọn đề tài Trong thời đại cách mạng công nghiệp 4.0, công nghệ thông tin đóng vai trị quan trọng hầu hết tất lĩnh vực đời sống xã hội Vì vậy, nhu cầu nguồn nhân lực công nghệ thông tin lớn, chương trình giáo dục phổ thơng có thay đổi mạnh mẽ để đáp ứng với yêu cầu xã hội hội nhập quốc tế Việc tạo nguồn nhân lực công nghệ thông tin vững mạnh nhiệm vụ quan trọng góp phần thúc đẩy phát triển kinh tế xã hội Từ năm học 2022-2023 em học sinh lớp 10 bắt đầu học chương trình giáo dục phổ thơng mới, nội dung mơn tin học có nhiều thay đổi, có nội dung học lập trình ngơn ngữ Python Là giáo viên tin học, việc dạy cho em kiến thức tin học việc khích lệ, động viên, tạo hứng thú cho em học lập trình thơng qua hệ thống tập từ đến nâng cao, tạo động lực cho em có lực, đam mê theo đuổi lĩnh vực cơng nghệ thơng tin, đóng góp vào đội ngũ nhân lực công nghệ thông tin chất lượng sau cho nước nhà việc cần thiết kn sk Học lập trình nhiều học sinh nội dung tương đối khó, dạy học lập trình tơi ln cố gắng nghiên cứu sách giáo khoa, tài liệu tham khảo, đúc rút kinh nghiệm dạy khóa trước để tìm cách dạy phù hợp, giúp học sinh tiếp cận giải vấn đề cách hiệu Qua góp phần gia tăng chất lượng số lượng học sinh u thích mơn tin học nói chung lập trình nói riêng Qua q trình dạy học lập trình bậc trung học phổ thông, nhận thấy phần kiến thức kiểu liệu danh sách xâu kí tự nội dung quan trọng, giáo viên cần có biện pháp hỗ trợ học sinh học tốt nội dung Từ trăn trở đó, tơi chọn đề tài “Xây dựng số tập kiểu liệu danh sách xâu kí tự nhằm hỗ trợ phát triển phẩm chất lực học sinh lớp 10 học lập trình ngơn ngữ Python”, giúp giáo viên học sinh có thêm tài liệu tham khảo hỗ trợ trình dạy học tốt Mục đích nghiên cứu Nhằm nâng cao hiệu việc học lập trình phần kiểu liệu danh sách xâu kí tự ngơn ngữ Python Từ tạo động lực, hứng thú, thúc đẩy đam mê để em tiếp tục học lập trình phần tốt Đối tượng nghiên cứu - Học sinh lớp 10 học theo chương trình giáo dục phổ thơng - Nghiên cứu lập trình ngơn ngữ Python, nội dung kiến thức liên quan đến kiểu liệu danh sách xâu kí tự - Xây dựng số tập thực viết code để xử lý Phương pháp nghiên cứu Kết hợp số phương pháp : - Nghiên cứu lý thuyết, nghiên cứu từ thực tiễn dạy học - Phương pháp thực nghiệm sư phạm: + Tổ chức hoạt động dạy học, lưu lại làm học sinh, khảo sát kết học tập, phân tích diễn biến q trình thực nghiệm, rút kinh nghiệm dạy, từ có điều chỉnh, bổ sung để hồn thiện đề tài Tính đề tài Đề tài triển khai trường trung học phổ thông Tân Kỳ hiệu quả, góp phần nâng cao chất lượng dạy học lập trình cho học sinh lớp 10 học chương trình giáo dục phổ thơng 2018 Giúp học sinh có nguồn tài liệu học tập bổ ích, đem lại niềm vui, hứng thú tạo động lực cho học sinh học lập trình Sáng kiến sử dụng làm tài liệu tham khảo cho giáo viên môn tin dạy học lập trình ngơn ngữ Python, nhằm nâng cao hiệu dạy học môn Tin trường trung học phổ thông kn sk PHẦN II NỘI DUNG NGHIÊN CỨU Cơ sở lý thuyết Tìm hiểu nội dung học liên quan đến kiểu liệu danh sách xâu kí tự chương trình tin học lớp 10 theo chương trình giáo dục phổ thơng 2018 Tìm hiểu thực trạng, độ hứng thú học sinh khó khăn vướng mắc học sinh học nội dung “kiểu liệu danh sách xâu kí tự” Nghiên cứu, rút kinh nghiệm qua năm dạy học sinh học lập trình ngôn ngữ pascal, C++, để cải tiến áp dụng cho dạy học lập trình ngơn ngữ python Tìm hiểu sở lý luận phương pháp dạy học lập trình ngơn ngữ python trường trung học phổ thơng Tìm hiểu cách xây dựng số tập kiểu liệu danh sách xâu kí tự Thực phương án giải toán nhằm phát triển phẩm chất lực học sinh, tạo hứng thú cho học sinh học lập trình, khơi dậy niềm đam mê tin học Cơ sở thực tiễn Hiện nhu cầu nguồn lao động xã hội cần nhiều người có trình độ tốt tin học, đặc biệt nguồn nhân lực có chất lượng cao cơng nghệ thơng tin kn sk Tuy nhiên việc đào bồi dưỡng học sinh u thích mơn tin trường trung học phổ thơng nói chung trường Tân Kỳ nói riêng cịn gặp nhiều khó khăn Do tâm lí chung nhiều phụ huynh học sinh xem môn tin mơn phụ nên em chưa có đầu tư quan tâm mức cho môn tin học Bên cạnh đó, q trình học lập trình nhiều em học sinh trang bị cho sách giáo khoa để học cịn tài liệu tham khảo chưa có điều kiện để mua chưa tìm tài liệu phù hợp Do đó, việc giáo viên tìm kiếm, xây dựng, trang bị, chia tài liệu hay phù hợp với chương trinh học đối tượng học sinh nhằm góp phần nâng cao chất lượng học lập trình thực tốt nhiệm vụ mơn học theo chương trình giáo dục phổ thơng 2018 việc cần thiết Giải pháp Nội dung sáng kiến tập trung vào xây dựng hệ thống tập kiểu liệu danh sách xâu kí tự từ mức độ đến mức độ nâng cao Mỗi tập đưa phân tích cách giải, có code tham khảo kèm kết chạy chương trình minh họa Hệ thống tập sau: 3.1 Bài tập kiểu liệu danh sách 3.1.1 Một số tập 3.1.1.1 Tìm hiểu danh sách Bài 1: Hãy lấy ví dụ về: danh sách màu sắc quen thuộc, danh sách 10 chữ in hoa bảng chữ tiếng Anh, danh sách tổ lớp Hướng dẫn: - Danh sách màu sắc quen thuộc: xanh, đỏ, tím, vàng, cam - Danh sách 10 chữ bảng chữ tiếng anh: A,B,C,D,E,F,G,H,I,J - Danh sách tổ lớp: Tổ 1, Tổ 2, Tổ 3, Tổ 3.1.1.2 Khởi tạo danh sách lệnh gán Bài 2: Hãy khởi tạo danh sách sau lệnh gán: danh sách A chứa số sau (3,5,2,4,8,9), danh sách B chứa tên màu (xanh, đỏ, tím, vàng, cam), danh sách C khơng chứa phần tử nào, danh sách D chứa giá trị (10, 15.5, “tin học”) Hướng dẫn: A=[3,5,2,4,8,9]; B=[ “xanh”, “đỏ”, “tím”, “vàng”, “cam”]; C=[]; D=[10, 15.5, “tin học”] 3.1.1.3 Bổ sung phần tử vào danh sách a Bổ sung phần tử vào cuối danh sách lệnh append() Hướng dẫn: ta viết lệnh kn sk Bài 3: Cho danh sách B=[ "xanh","đỏ","tím"] bổ sung màu “vàng “ vào cuối danh sách B B.append("vàng") Hình ảnh minh họa chụp từ phần mềm Python: b Bổ sung n phần tử vào cuối danh sách lệnh append() kết hợp với vòng lặp Bài 4: Cho danh sách A=[3,5,2,4,8,9], bổ sung n số nguyên vào cuối danh sách A (n nhập từ bàn phím) Hướng dẫn: Ta cần nhập số nguyên dương n để biết số lượng phần tử cần bổ sung, sau dùng lệnh append() để bổ sung phần tử vào danh sách A Chú ý trường hợp lệnh append sử dụng n lần nên ta sử dụng câu lệnh for để điều khiển việc bổ sung phần tử Chương trình viết sau: Kết chạy chương trình minh họa với n=5: c Bổ sung phần tử x vào vị trí k lệnh insert(k,x) kn sk Bài 5: Cho danh sách A=[6,8,10,7,5,3] chèn số nguyên x (x nhập từ bàn phím) vào vị trí có số danh sách A ( ý: số phần tử danh sách đánh từ 0) Ta viết chương trình tham khảo sau: A=[6,8,10,7,5,3] x=int(input("hay nhap so nguyen x= ")) A.insert(3,x) print(A) Kết chạy chương trình minh họa : d Tạo danh sách gồm n số nguyên Bài 6: Viết chương trình nhập vào danh sách A có n số nguyên In hình danh sách vừa tạo Chương trình tham khảo: Gợi ý: Chương trình minh họa Kết chạy chương trình minh họa sau: 3.1.1.4 Nối ghép danh sách phép + lệnh extend() Bài Cho danh sách A=[1,2,3], danh sách B=[4,5,6] Hãy ghép danh sách B vào danh sách A Chương trình tham khảo cách sử dụng phép ghép danh sách (+) Chương trình minh họa cách sử dụng lệnh extend() kn sk 3.1.1.5 Xóa phần tử danh sách a Xóa toàn liệu danh sách lệnh clear() Bài 8: Cho danh sách A=[6,8,10,7,5,3] Viết lệnh xóa tồn danh sách A Chương trình tham khảo cho kết sau: Chú ý: sau xóa danh sách A lệnh clear(), danh sách A trở thành rỗng b Xóa phần tử x có danh sách lệnh remove(x) Bài 9: Cho danh sách A=[6,8,10,7,5,3] Hãy xóa phần tử có giá trị 10 Chương trình tham khảo: Kết chạy chương trình sau: Chú ý: phần tử x để xóa khơng có danh sách máy báo lỗi 3.1.1.6 Kiểm tra độ dài thời danh sách lệnh len() Bài 10: Viết chương trình nhập vào danh sách A có n số nguyên (n nhập từ bàn phím) Thơng báo lên hình độ dài danh sách A Chương trình tham khảo kết quả: kn sk 3.1.1.7 Duyệt tìm kiếm danh sách lệnh for kết hợp với lệnh range() Bài 11: Viết chương trình nhập vào danh sách A có n số ngun (n nhập từ bàn phím) Thơng báo lên hình số chẵn có danh sách A theo thứ tự từ trái qua phải Chương trình tham khảo cho kết sau: Bài 12: Viết chương trình nhập vào danh sách A có n số ngun ( n nhập từ bàn phím) số nguyên k Tính tổng số chia hết cho k có danh sách A Thơng báo kết tính hình Chương trình tham khảo sau: A=[]; t=0; n=int(input("hay nhap so luong phan tu = ")) for i in range(1,n+1): x=int(input("phan tu thu "+str(i)+"=")) A.append(x) k=int(input("hay nhap k= ")) for i in range(0,n): if A[i]% k==0: t=t+A[i] print("tong cac so chia het cho k co day A = ",t) Kết chạy chương trình minh họa với n=6; k=3 kn sk Chú ý: ta duyệt tìm kiếm danh sách vòng lặp while để giải cho toán sau: A=[]; t=0; i=0 n=int(input("hay nhap so luong phan tu = ")); k=int(input("hay nhap k= ")) print("hay nhap cac phan tu vao danh sach A:") while i1 ta thực hiện: st = st + str(dem)+s[i]; gán lại dem=1 Ngược lại dem=1 st=st+s[i] Chú ý: ta kiểm tra s[i] s[i+1] nên để không bị sai i cuối dãy ta cần thêm vào xâu ban đầu kí tự để canh, ví dụ „1‟ chẳng hạn Chương trình tham khảo s = input("Nhap xau s="); st = "" # khoi tao xau ket qua, ban dau rong dem = #so ki tu day ki tu lien tiep n = len(s) s = s + '1' #them vao xau s mot ki tu de canh for i in range(n): if s[i] == s[i+1]: dem = dem + elif dem>1: st = st + str(dem)+s[i] dem=1 st=st+s[i] kn sk else: print("xau nen: ",st) Kết chạy chương trình minh họa: 3.2.2.8 Giải nén xâu Bài 8: Viết chương trình giải nén xâu gồm chữ la tinh Biết xâu nén theo quy tắc: với kí tự liên tiếp giống ta thay dãy bằng: Ví dụ: „2a2bc3d3f‟  „aabbcdddfff‟  Ý tưởng thuật toán: - Dùng biến s để lưu xâu nén ban đầu; s1 xâu tạm giải nén đoạn con; s2 xâu giải nén kết - Duyệt từ đầu xâu s đến cuối xâu s, chữ ta đưa vào s2: if (s[i]"9"): s2=s2+s[i] Ngược lại chữ số ta giải nén đoạn đưa vào s1 ghép vào s2: s1=int(s[i])*s[i+1] s2=s2+s1 36 s1="" # khởi tạo lại s1=rỗng - Kết thúc vòng lặp ta s2 xâu kết Chương trình minh họa: s=input("nhap xau de giai nen: ") s1=""; s2=""; i=0; while i

Ngày đăng: 02/10/2023, 14:47

TÀI LIỆU CÙNG NGƯỜI DÙNG

TÀI LIỆU LIÊN QUAN

w