Rumah >pembangunan bahagian belakang >C++ >Bagaimanakah anda boleh mencari semua subset yang mungkin bagi set dengan n elemen menggunakan pendekatan rekursif?
Mencari Semua Subset Set
Dalam sains komputer, mencari semua subset bagi set tertentu adalah masalah klasik. Timbul persoalan seperti berikut:
Masalah:
Bagaimana untuk menentukan semua kemungkinan subset bagi set dengan n elemen?
Penyelesaian:
Pendekatan mudah untuk masalah ini terletak pada rekursi. Konsep ini berkisar pada idea bahawa:
Contoh:
Pertimbangkan n=5.
Pelaksanaan C:
#include <vector> using namespace std; vector<vector<int>> subsets(vector<int>& nums) { if (nums.empty()) return {{}}; vector<vector<int>> prev = subsets(vector<int>(nums.begin(), nums.end() - 1)); vector<vector<int>> curr; for (auto& subset : prev) { curr.push_back(subset); subset.push_back(nums.back()); curr.push_back(subset); } return curr; }
Atas ialah kandungan terperinci Bagaimanakah anda boleh mencari semua subset yang mungkin bagi set dengan n elemen menggunakan pendekatan rekursif?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!