Bài 58. Đảo ngược chuỗi trong C/C++

2
2365

Để luyện tập kiến thức về chuỗi trong C, hôm nay Lập trình không khó sẽ cùng các bạn đi làm bài tập đảo ngược chuỗi nhập từ bàn phím trong ngôn ngữ C/C++. Chúng ta sẽ cùng nhau thực hiện đảo ngược chuỗi không sử dụng hàm và đảo ngược chuỗi sử dụng hàm có sẵn trong các thư viện của ngôn ngữ C/C++.

Input

Output

Nội dung bài viết

Mình xin 5 phút quảng cáo nha =))

Đảo ngược chuỗi không dùng hàm có sẵn

Nếu chưa biết cách nhập chuỗi các bạn có thể xem lại cách nhập chuỗi tại đây.

Đầu tiên các bạn phải đếm xem chuỗi có bao nhiêu kí tự. Với nhiệm vụ này thì mình sẽ viết riêng một hàm Length() trả về số lượng kí tự trong chuỗi. Lưu ý khi các bạn nhập chuỗi vào sử dụng hàm fgets() thì nó sẽ đọc cả kí tự '\n' (hay kí tự enter) vào cuối chuỗi. Nhiệm vụ của các bạn là không đếm kí tự này.

Sau khi có được số lượng kí tự trong chuỗi, việc tiếp theo sẽ là đảo ngược chuỗi. Các bạn sẽ dùng một con trỏ kiểu char để lưu lại chuỗi đảo ngược.

Cuối cùng hàm DaoNguoc sẽ trả về con trỏ mà chúng ta dùng để lưu kí tự.

Nếu bạn chỉ cần xuất ra thì có thể dùng 1 vòng for theo hướng ngược lại như hàm InDaoNguoc.

Lời giải tham khảo:

Đảo ngược chuỗi sử dụng hàm có sẵn

Với ngôn ngữ lập trình C

Ngôn ngữ C có thư viện string.h, trong đó có hàm strrev() giúp chúng ta có thể đảo ngược chuỗi một cách đơn giản:

Kết quả:

Với ngôn ngữ C++

Với việc sử dụng thư viện string thì bạn không cần phải đếm số lượng kí tự nữa rồi! Rất tiện lợi phải không.

Đầu tiên thì bạn khởi tạo một temp(kiểu string) trống, sau đó ta lần lượt thêm từng kí tự vào cuối temp. Ta sẽ sử dụng hàm pusk_back để thêm kí tự vào cuối temp. Bây giờ nhiệm vụ của chúng ta là lấy từng kí tự của s theo chiều từ sau tới và thêm vào temp.

Cuối cùng hàm DaoNguoc sẽ trả về temp, chính là chuỗi đã đảo ngược.

Hoặc đơn giản hơn rất nhiều nếu sử dụng hàm sau đây:

Kết quả:

Bài viết mình đến đây cũng xin kết thúc. Cám ơn các bạn đã theo dõi !

Theo dõi lập trình không khó tại:

avatar
  Subscribe  
newest oldest most voted
Notify of
Thanh Bình
Guest
Thanh Bình

– Admin giải thích giúp em 2 lệnh: cin.ignore() và cin.clear() …được không ạ?? Em search google nhưng đa phần toàn Tiếng Anh, nên không hiểu được(đặc biệt là cái cin.clear) 😢 ….cảm ơn Ad ^_^

Nguyễn Văn Hiếu
Admin
Nguyễn Văn Hiếu

Câu hỏi này khá hay đấy. – Hàm cin.clear() được dùng để xóa flag nếu có của những lần nhập trước đó. Cụ thể, trong trường hợp nhập trước đó mà có lỗi xảy ra thì sẽ có 1 flag lỗi gán vào thằng cin, dần đến các lần nhập sau bị lỗi. Bạn đọc thêm số [1] – Hàm cin.ignore() mặc định không tham số sẽ bỏ qua 1 ký tự trong cin buffer. Cụ thể, nếu trước đó bạn nhập 1 số nguyên(sử dụng enter để kết thúc nhập) thì ‘\n’ vẫn được lưu lại trong buffer ->… Read more »