用 C++ 計算乘積小於 K 的所有子序列
在本教程中,我們將討論一個程式,以查詢在產品中乘積小於 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
廣告
資料結構
網路
RDBMS
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP