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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

SCAU 算法课的题

發(fā)布時(shí)間:2023/12/9 编程问答 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SCAU 算法课的题 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

8594?有重復(fù)元素的排列問題(優(yōu)先做)

時(shí)間限制:1000MS? 內(nèi)存限制:1000K
提交次數(shù):1610 通過次數(shù):656

題型: 編程題???語言: G++;GCC;VC

?

Description

設(shè)集合R={r1,r2,...,rn}是要進(jìn)行排列的n個(gè)元素,其中r1,r2,...,rn可能相同。 試著設(shè)計(jì)一個(gè)算法,列出R的所有不同排列。 即,給定n以及待排的n個(gè)可能重復(fù)的元素。計(jì)算輸出n個(gè)元素的所有不同排列。




輸入格式

第1行是元素個(gè)數(shù)n,1<=n<=15。接下來的1行是待排列的n個(gè)元素,元素中間不要加空格。



輸出格式

程序運(yùn)行結(jié)束時(shí),將計(jì)算輸出n個(gè)元素的所有不同排列。最后1行中的數(shù)是排列總數(shù)。(說明: 此題,所有計(jì)算出的排列原本是無所謂順序的。但為了容易評(píng)判,輸出結(jié)果必須唯一! 現(xiàn)做約定:所有排列的輸出順序如課本例2-4的程序段的輸出順序,區(qū)別僅是這道題是含 重復(fù)元素。)



?

輸入樣例

4 aacc



?

輸出樣例

aacc acac acca caac caca ccaa 6

?

?

構(gòu)造函數(shù)F(be, en)表示要對(duì)這個(gè)區(qū)間進(jìn)行全排列
那么F(be, en)的結(jié)果相當(dāng)于第一位是誰誰誰的 + F(be + 1, en)的結(jié)果
如果可以重復(fù),那么第一位沒有限定
但是這題有重復(fù),那么和第一位換過的元素就不能再次換
就相當(dāng)于第一位只能出現(xiàn)a、b、c、d、e.....只能一次

?

?

#include <cstdio> #include <cstring> #include <cstdlib> #include <algorithm> using namespace std; #define IOS ios::sync_with_stdio(false) using namespace std; #define inf (0x3f3f3f3f) typedef long long int LL; char str[222]; int ans; bool is[22][222]; void fun(int be, int en) {if (be == en) {ans++;printf("%s\n", str + 1);return;}is[be][str[be]] = true;fun(be + 1, en);for (int i = be + 1; i <= en; ++i) {if (is[be][str[i]]) continue;is[be][str[i]] = true;swap(str[be], str[i]);fun(be + 1, en);swap(str[be], str[i]);}memset(is[be], false, sizeof is[be]); } void work() {int lenstr;scanf("%d", &lenstr);scanf("%s", str + 1);fun(1, lenstr);printf("%d\n", ans); }int main() { #ifdef localfreopen("data.txt", "r", stdin); // freopen("data.txt", "w", stdout); #endifwork();return 0; } View Code

?

轉(zhuǎn)載于:https://www.cnblogs.com/liuweimingcprogram/p/7764529.html

創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)

總結(jié)

以上是生活随笔為你收集整理的SCAU 算法课的题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。