ในบทช่วยสอนนี้ เราจะพูดถึงโปรแกรมเพื่อค้นหาจำนวนลำดับย่อยที่มีผลิตภัณฑ์น้อยกว่า K
สำหรับสิ่งนี้ เราจะได้รับอาร์เรย์ที่ไม่ใช่ค่าลบและค่า k งานของเราคือค้นหาลำดับย่อยทั้งหมดในอาร์เรย์ที่มีผลิตภัณฑ์น้อยกว่า k
ตัวอย่าง
#include <bits/stdc++.h> using namespace std; //counting subsequences with product //less than k int count_sub(vector<int> &arr, int k){ int n = arr.size(); int dp[k + 1][n + 1]; memset(dp, 0, sizeof(dp)); for (int i = 1; i <= k; i++) { for (int j = 1; j <= n; j++) { dp[i][j] = dp[i][j - 1]; if (arr[j - 1] <= i && arr[j - 1] > 0) dp[i][j] += dp[i/arr[j-1]][j-1] + 1; } } return dp[k][n]; } int main(){ vector<int> A; A.push_back(1); A.push_back(2); A.push_back(3); A.push_back(4); int k = 10; cout << count_sub(A, k) << endl; }
ผลลัพธ์
11