Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> C++

นับลำดับย่อยทั้งหมดที่มีผลิตภัณฑ์น้อยกว่า K ใน C++


ในบทช่วยสอนนี้ เราจะพูดถึงโปรแกรมเพื่อค้นหาจำนวนลำดับย่อยที่มีผลิตภัณฑ์น้อยกว่า 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