ให้ n, r, k ตอนนี้เราต้องค้นหาว่าเราสามารถเลือกสิ่งของ r จาก n ได้อย่างไร เพื่อให้ k เฉพาะเกิดขึ้นพร้อมกัน เป็นต้น
Input : n = 8, r = 5, k = 2 Output : 960 Input : n = 6, r = 2, k = 2 Output : 2
เราต้องการความรู้เล็กน้อยสำหรับปัญหานี้เพราะปัญหานี้ขอให้เราค้นหาการเรียงสับเปลี่ยนของ n และ r จนทำให้ k มารวมกัน
แนวทางในการหาแนวทางแก้ไข
เราจำเป็นต้องกำหนดสูตรของเราสำหรับคำถามนี้ และนั่นจะให้คำตอบแก่เรา
ตัวอย่าง
#include <bits/stdc++.h>
using namespace std;
int fact(int n){ // function to calculate factorial of a number
if(n <= 1)
return 1;
return n * fact(n-1);
}
int npr(int n, int r){ // finding permutation
int pnr = fact(n) / fact(n - r);
return pnr;
}
int countPermutations(int n, int r, int k){ // the formula that we came up with
return fact(k) * (r - k + 1) * npr(n - k, r - k);
}
int main(){
int n = 8;
int r = 5;
int k = 2;
cout << countPermutations(n, r, k);
return 0;
} ผลลัพธ์
960
คำอธิบายของโค้ดด้านบน
ในแนวทางข้างต้น เราพยายามคิดค้นสูตรในการคำนวณคำตอบสำหรับปัญหานี้ สูตรที่เราคิดค้นคือ (k!) * (r - k + 1) * P(n-k, r-k) ( P(x, y) คือจำนวนการเรียงสับเปลี่ยนของการเลือก y จาก x) ดังนั้นเราจึงนำสูตรของเรามาคำนวณหาคำตอบ
บทสรุป
ในบทช่วยสอนนี้ เราแก้ปัญหาเพื่อค้นหาการเรียงสับเปลี่ยนของ n ตัวที่นำ r ครั้งละ r ด้วย k ตัวเข้าด้วยกัน นอกจากนี้เรายังได้เรียนรู้โปรแกรม C++ สำหรับปัญหานี้และแนวทางที่สมบูรณ์ ( Normal) ซึ่งเราแก้ปัญหานี้ได้
เราสามารถเขียนโปรแกรมเดียวกันในภาษาอื่นๆ เช่น C, java, python และภาษาอื่นๆ เราหวังว่าคุณจะพบว่าบทช่วยสอนนี้มีประโยชน์