拍集體照時隊形很重要,這裏對給定的 N 我的 K 排的隊形設計排隊規則以下:node
每排人數爲 /(向下取整),多出來的人所有站在最後一排;ios
後排全部人的個子都不比前排任何人矮;數組
每排中最高者站中間(中間位置爲 /,其中 m 爲該排人數,除法向下取整);框架
每排其餘人以中間人爲軸,按身高非增序,先右後左交替入隊站在中間人的兩側(例如5人身高爲190、18八、18六、17五、170,則隊形爲17五、18八、190、18六、170。這裏假設你面對拍照者,因此你的左邊是中間人的右邊);函數
若多人身高相同,則按名字的字典序升序排列。這裏保證無重名。測試
現給定一組拍照人,請編寫程序輸出他們的隊形。spa
輸入格式:
每一個輸入包含 1 個測試用例。每一個測試用例第 1 行給出兩個正整數 N(≤,總人數)和 K(≤,總排數)。隨後 N 行,每行給出一我的的名字(不包含空格、長度不超過 8 個英文字母)和身高([30, 300] 區間內的整數)。設計
輸出格式:
輸出拍照的隊形。即K排人名,其間以空格分隔,行末不得有多餘空格。注意:假設你面對拍照者,後排的人輸出在上方,前排輸出在下方。code
輸入樣例:
10 3 Tom 188 Mike 170 Eva 168 Tim 160 Joe 190 Ann 168 Bob 175 Nick 186 Amy 160 John 159輸出樣例:
Bob Tom Joe Nick Ann Mike Eva Tim Amy John
1 #include <cstdio> 2 #include <cstring> 3 #include <cctype> 4 #include <iostream> 5 #include <sstream> 6 #include <cmath> 7 #include <algorithm> 8 #include <string> 9 #include <stack> 10 #include <queue> 11 #include <vector> 12 #include <map> 13 using namespace std; 14 15 struct node{ 16 string s; 17 int h; 18 }per[10005]; 19 20 bool cmp(node a, node b) 21 { 22 if(a.h == b.h) 23 return a.s < b.s; 24 else 25 return a.h > b.h; 26 } 27 28 int main() 29 { 30 int n, k; 31 scanf("%d %d", &n, &k); 32 for(int i = 0; i < n; i++) 33 { 34 cin >> per[i].s >> per[i].h; 35 } 36 sort(per, per + n, cmp); 37 int m = n / k; //各排的人數 38 int fm = m + n % k; //最後一排的人數 39 for(int i = 0; i < k; i++) 40 { 41 if(i == 0 && n%k) //如有人多出放最後一排特殊處理 42 { 43 for(int j = fm-1; j > 0; j-=2) //輸出 左列 44 { 45 cout << per[j].s; 46 printf(" "); 47 } 48 for(int j = 0; j < fm; j+=2) //輸出 右列 49 { 50 cout << per[j].s; 51 if(j != fm-2) 52 printf(" "); 53 } 54 printf("\n"); 55 } 56 else 57 { 58 if(m % 2) //若是一排人數奇數個 59 { 60 for(int j = fm+i*m-2; j > fm+(i-1)*m; j-=2) //輸出 左列 61 { 62 cout << per[j].s; 63 printf(" "); 64 } 65 for(int j = fm+(i-1)*m; j < fm+i*m; j+=2) //輸出 右列 66 { 67 if(j != fm+(i-1)*m) 68 printf(" "); 69 cout << per[j].s; 70 } 71 printf("\n"); 72 } 73 else //每排偶數個 74 { 75 for(int j = fm+i*m-1; j > fm+(i-1)*m; j-=2) //輸出 左列 76 { 77 cout << per[j].s; 78 printf(" "); 79 } 80 for(int j = fm+(i-1)*m; j < fm+i*m; j+=2) //輸出 右列 81 { 82 if(j != fm+(i-1)*m) 83 printf(" "); 84 cout << per[j].s; 85 } 86 printf("\n"); 87 } 88 } 89 } 90 return 0; 91 }
打代碼就像寫文章,不斷修改才能不斷加深功底,思路是框架,填充好細節才成文。真正的快樂來源於不斷的嘗試與失敗後終於迎來的成功。blog