網(wǎng)站備案登記查詢系統(tǒng)刷seo關(guān)鍵詞排名軟件
?解題心得:
寫遞歸函數(shù)的時(shí)候,首先寫終止條件,這有助于對(duì)整個(gè)遞歸函數(shù)的把握。
題目:輸入集合A和B,輸出A到B上的所有函數(shù)。
問(wèn)題描述
給定非空數(shù)字集合A和B,求出集合A到集合B上的所有函數(shù)。
輸入格式
第一行輸入m和n(空格間隔),分別為集合A和集合B中的元素個(gè)數(shù); 第二行輸入非空數(shù)字集合A,每個(gè)元素之間用空格間隔; 第三行輸入非空數(shù)字集合B,每個(gè)元素之間用空格間隔。
輸出格式
輸出每一行為集合A到集合B的一個(gè)構(gòu)成函數(shù)的二元關(guān)系,按二元關(guān)系的基數(shù)大小從小到大輸出所有二元關(guān)系,相同基數(shù)的二元關(guān)系按序偶中元素的字典序排列。
樣例輸入
2 2
1 2
3 4
樣例輸出
{<1,3>,<2,3>}
{<1,3>,<2,4>}
{<1,4>,<2,3>}
{<1,4>,<2,4>}
實(shí)現(xiàn)思路:
- 預(yù)處理:利用優(yōu)先隊(duì)列將集合中元素從小到大放進(jìn)數(shù)組A,B中
- 遞歸實(shí)現(xiàn):每行中A的元素全部被輸出,是確定的,我們用遞歸更新B中要輸出的元素,并在每次遞歸的末端cout一行結(jié)果
總體代碼實(shí)現(xiàn)(已給出代碼注釋)
#include<bits/stdc++.h>
using namespace std;int main()
{//預(yù)處理:利用優(yōu)先隊(duì)列將集合中元素從小到大放進(jìn)數(shù)組A,B中int m, n, cur;cin>>m>>n;priority_queue<int>pq; vector<int>A(m);vector<int>B(n);for(int i=0; i<m; i++) {cin>>cur; pq.push(cur);}for(int i=1; i<=m; i++) {A[m-i] = pq.top(); pq.pop(); }for(int i=0; i<n; i++) {cin>>cur; pq.push(cur);}for(int i=1; i<=n; i++) {B[n-i] = pq.top(); pq.pop(); }//觀察輸出樣例:每行輸出均有A中全部元素,B對(duì)應(yīng)元素每行只有一處變化vector<int>q(m);//q[i]攜帶了當(dāng)前映射關(guān)系中A[i]對(duì)應(yīng)的集合B中元素//為什么用遞歸:因?yàn)锳中元素?cái)?shù)量不確定,事實(shí)上,如果用for循環(huán)嵌套,那么for循環(huán)的數(shù)量為 m,這是不能在確定的代碼中實(shí)現(xiàn)的auto dfs = [&](auto& dfs, int cnt) -> void{if(cnt == m)//遞歸終止條件{cout<<"{";for(int i=0; i<m; i++){cout<<"<"<<A[i]<<","<<q[i]<<">"; if(i == m-1) cout<<"}"<<endl;else cout<<",";}return; }else{for(int i=0; i<n; i++){q[cnt] = B[i];dfs(dfs, cnt+1);} return;}};dfs(dfs, 0);return 0;}