Hàm hoán vị trong C
1. Tư tưởng hoán vị
Trong thực tế, chúng ta phải xây dựng các chương trình, các hàm hoán vị để hoán đổi giá trị của các phần tử, ví dụ chương trình sắp xếp dãy là một điển hình.
Để hoán vị 2 số, ta có thể hình dung giống như chúng ta có 2 cốc. Cốc A đựng nước chanh, cốc B đựng thuốc trừ sâu. Làm sao để chúng ta chuyển nước chanh sang cốc B và chuyển thuốc trừ sâu sang cốc a? Đơn giản là dùng thêm 1 cốc phụ là cốc c và bắt đầu chuyển:
- B1: Đổ cốc chanh A sang cốc C. => A rỗng, C chứa chanh
- B2: Đổ cốc thuốc trừ sâu B sang cốc A => B rỗng, A chứa thuốc trừ sâu
- B3: Đổ cốc chanh C sang cốc B => B chứa chanh.
- Ok. Giờ A chứa thuốc trừ sâu, B chứa nước chanh.
2. Code hoán vị
Làm tương tự trong lập trình ta sẽ hoán đổi được giá trị của 2 biến.
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 | // e.g about swap in C - code by nguyenvanquan7826 #include <stdio.h> int main() { int a, b; printf ( "Nhap 2 so a, b:\n" ); scanf ( "%d%d" , &a, &b); printf ( "Ban da nhap:\na = %d \nb = %d\n" , a, b); int temp = a; a = b; b = temp; printf ( "Sau khi hoan vi:\na = %d\nb = %d\n" , a, b); return 0; } |
Kết quả:
Nhap 2 so a, b:
3
6Ban da nhap:
a = 3
b = 6Sau khi hoan vi:
a = 6
b = 3
Ok. Bây giờ thử tách ra thành hàm hoán vị xem sao:
3. Hàm hoán vị trong C
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | // e.g about swap in C - code by nguyenvanquan7826 #include <stdio.h> void hoanvi( int a, int b) { int temp = a; a = b; b = temp; } int main() { int a, b; printf ( "Nhap 2 so a, b:\n" ); scanf ( "%d%d" , &a, &b); printf ( "Ban da nhap:\na = %d \nb = %d\n" , a, b); hoanvi(a, b); printf ( "Sau khi goi ham hoanvi:\na = %d\nb = %d \n" , a, b); return 0; } |
Kết quả:
Nhap 2 so a, b:
3
6Ban da nhap:
a = 3
b = 6Sau khi goi ham hoanvi:
a = 3
b = 6
Oh, Sao kết quả chúng ta không có sự hoán vị?
Với chương trình này chúng ta xây dựng 1 hàm hoán vị để đổi vị trí giữa 2 bến a và b, tuy nhiên chúng ta đã sử dụng tham trị nên các giá trị của a và b không thay đổi hay nói cách khác là chúng không được hoán vị cho nhau.
Các bạn hiểu truyền tham trị tức là khi gọi hàm hoanvi(a, b) thì ngay lập tức giá trị của a và b (3 và 6) được đưa vào hàm chứ không phải là các biến a, b nên biến a, b của chúng ta không hề thay đổi khi hàm kết thúc.
Code đúng như sau:
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | // e.g about swap in C - code by nguyenvanquan7826 #include <stdio.h> void hoanvi( int *a, int *b) { int temp = *a; *a = *b; *b = temp; } int main() { int a, b; printf ( "Nhap 2 so a, b:\n" ); scanf ( "%d%d" , &a, &b); printf ( "Ban da nhap:\na = %d \nb = %d\n" , a, b); hoanvi(&a, &b); printf ( "Sau khi goi ham hoanvi:\na = %d\nb = %d \n" , a, b); return 0; } |
Kết quả:
Nhap 2 so a, b:
3
6Ban da nhap:
a = 3
b = 6Sau khi hoan vi:
a = 6
b = 3
Ở trên chúng ta xây dựng hàm hoanvi với 2 đối số là *a
và *b
kiểu int. *a
và *b
nghĩa là con trỏ a và con trỏ b. Trong thân hàm chúng ta có viết *a
, *b
(VD: int temp = *a
) thì dấu *
thể hiện là giá trị của con trỏ a.
Do hàm dùng con trỏ nên khi gọi hàm chúng ta phải truyền vào địa chỉ của các biến tức là hoanvi(&a, &b)
, ở đây dấu &
để lấy địa chỉ của biến a và biến b.
4. Hàm hoán vị trong C++
Nếu các bạn viết trong C++ (file có đuôi là .cpp) thì có thể viết hàm hoán vị dễ hơn một chút như sau.
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | // e.g about swap in C - code by nguyenvanquan7826 #include <stdio.h> void hoanvi( int &a, int &b) // only in C++, file .cpp { int temp = a; a = b; b = temp; } int main() { int a, b; printf ( "Nhap 2 so a, b:\n" ); scanf ( "%d%d" , &a, &b); printf ( "Ban da nhap:\na = %d \nb = %d\n" , a, b); hoanvi(a, b); printf ( "Sau khi goi ham hoanvi:\na = %d\nb = %d \n" , a, b); return 0; } |
Hoặc có thể dùng hàm swap có sẵn trong thư viện algorithm
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 | #include <stdio.h> #include <algorithm> // swap int main() { int a, b; printf ( "Nhap 2 so a, b:\n" ); scanf ( "%d%d" , &a, &b); printf ( "Ban da nhap:\na = %d \nb = %d\n" , a, b); std::swap(a, b); printf ( "Sau khi goi ham hoanvi:\na = %d\nb = %d \n" , a, b); return 0; } |
Hay quá! Giờ em mới biết
Nhờ bạn giải thích nguyên chỗ này đc ko
int temp = a;
a = b;
b = temp;
nó là 3 lệnh để đổi giá trị a và b cho nhau thông qua temp. giống như có 2 cốc nước A, B đựng chanh và muốn, muốn đổi cho nhau thì cần thêm cốc temp ko đựng gì ấy.
Vậy cho mình hỏi int temp là khai báo gì vậy ạk
là khai báo biến kiểu nguyên, giống như int a, int b ý.
dạ cho em hỏi là nếu đề bài yêu cầu mình hoán vị 5 số nguyên thì mình vẫn dùng được biến tạm hay sao ạ?
đúng rồi bạn.
a ơi cho em làm quen với , nhờ a kết bạn với em qua zalo để nhờ chỉ dạy chia sẽ kinh nghiệm với.sdt em .0966771824.mong a kb với em