演算法訓練 星際交流
時間限制:1.0s 記憶體限制:256.0mb
問題描述
人類終於登上了火星的土地並且見到了神秘的火星人。人類和火星人都無法理解對方的語言,但是我們的科學家發明了一種用數字交流的方法。這種交流方法是這樣 的,首先,火星人把乙個非常大的數字告訴人類科學家,科學家破解這個數字的含義後,再把乙個很小的數字加到這個大數上面,把結果告訴火星人,作為人類的回 答。
火星人用一種非常簡單的方式來表示數字——掰手指。火星人只有乙隻手,但這只手上有成千上萬的手指,這些手指排成一列,分別編號為1,2,3……。火星人的任意兩根手指都能隨意交換位置,他們就是通過這方法計數的。
乙個火星人用乙個人類的手演示了如何用手指計數。如果把五根手指——拇指、食指、中指、無名指和小指分別編號為1,2,3,4和5,當它們按正常順序排列 時,形成了5位數12345,當你交換無名指和小指的位置時,會形成5位數12354,當你把五個手指的順序完全顛倒時,會形成54321,在所有能夠形 成的120個5位數中,12345最小,它表示1;12354第二小,它表示2;54321最大,它表示120。下表展示了只有3根手指時能夠形成的6個 3位數和它們代表的數字:
三進製數
123132
213231
312321
代表的數字 1
2 3
4 5
6現在你有幸成為了第乙個和火星人交流的地球人。乙個火星人會讓你看他的手指,科學家會告訴你要加上去的很小的數。你的任務是,把火星人用手指表示的數與科 學家告訴你的數相加,並根據相加的結果改變火星人手指的排列順序。輸入資料保證這個結果不會超出火星人手指能表示的範圍。
輸入格式
包括三行,第一行有乙個正整數n,表示火星人手指的數目(1 <= n <= 10000)。第二行是乙個正整數m,表示要加上去的小整數(1 <= m <= 100)。下一行是1到n這n個整數的乙個排列,用空格隔開,表示火星人手指的排列順序。
輸出格式
只有一行,這一行含有n個整數,表示改變後的火星人手指的排列順序。每兩個相鄰的數中間用乙個空格分開,不能有多餘的空格。
樣例輸入 5
31 2 3 4 5
樣例輸出
1 2 4 5 3
資料規模和約定
對於30%的資料,n<=15;
對於60%的資料,n<=50;
對於全部的資料,n<=10000;
tips:遞增生成排列數序列並計數
#include#include#include#includeusing namespace std;
int n,m,cnt,flag;
int a[11000];
int main()
{ cin>>n>>m;
for(int i=0;i
藍橋杯 演算法訓練 星際交流
問題描述 人類終於登上了火星的土地並且見到了神秘的火星人。人類和火星人都無法理解對方的語言,但是我們的科學家發明了一種用數字交流的方法。這種交流方法是這樣 的,首先,火星人把乙個非常大的數字告訴人類科學家,科學家破解這個數字的含義後,再把乙個很小的數字加到這個大數上面,把結果告訴火星人,作為人類的回...
藍橋杯演算法訓練題集
algo 1 區間k大數查詢 include include include include include using namespace std int a 1005 int tmp 1005 int ans 1005 bool cmp int a,int b int maxsort int l...
藍橋杯演算法訓練 網路流裸題
問題描述 乙個有向圖,求1到n的最大流 輸入格式 第一行n m,表示點數與邊數 接下來m行每行s t c表示一條從s到t的容量為c的邊 輸出格式 乙個數最大流量 樣例輸入 6 10 1 2 4 1 3 8 2 3 4 2 4 4 2 5 1 3 4 2 3 5 2 4 6 7 5 4 6 5 6 3...