日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

数论--康托展开与逆康托展开模板

發布時間:2023/12/15 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 数论--康托展开与逆康托展开模板 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

ACM常用模板合集

#include<bits/stdc++.h>using namespace std; const int MAX = 13; int Fac[MAX],N; //求出階乘 void init(){Fac[0] = 1;for(int i=1;i<=N;++i){Fac[i] = Fac[i-1]*i;} } //康托展開 int Cantor(int *x){int res = 0;for(int i=1;i<=N;++i){int Count = 0;for(int j=i+1;j<=N;++j){if(x[j] < x[i])Count++;}res += Fac[N-i]*Count;}return res; } //逆康托展開 void DeCantor(int pos,int *x){set<int> st;for(int i=1;i<=N;++i){st.insert(i);}for(int i=1;i<=N;++i){int r = pos / Fac[N-i];int l = pos % Fac[N-i];pos = l;set<int>::iterator it;int Count = 0;for(it = st.begin();it != st.end();++it){Count++;if(Count == r+1){break;}}x[i] = *it;st.erase(it);} } int main(void){int x[MAX],pos;cin >> N;init();cin >> pos;DeCantor(pos,x);cout << "DeCantor:" << endl;for(int i=1;i<=N;++i){cout << x[i] << " ";}cout << endl;cout << "Cantor:" << endl;cout << Cantor(x) << endl;return 0; }

風格2:

void init(){Fac[0] = 1;for(int i=1;i<=N;++i){Fac[i] = Fac[i-1]*i;} }int kangtuo(int n,char a[]) {int i,j,t,sum;sum=0;for( i=0; i<n ;++i){t=0;for(j=i+1;j<n;++j)if( a[i]>a[j] )++t;sum+=t*fac[n-i-1];}return sum+1; } void reverse_kangtuo(int n,int k,char s[]) {int i, j, t, vst[8]={0};--k;for (i=0; i<n; i++){t = k/fac[n-i-1];for (j=1; j<=n; j++)if (!vst[j]){if (t == 0) break;--t;}s[i] = '0'+j;vst[j] = 1;k %= fac[n-i-1];} }

總結

以上是生活随笔為你收集整理的数论--康托展开与逆康托展开模板的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。