1055. 集体照 (25)
2016-04-06 12:51
183 查看
拍集体照时队形很重要,这里对给定的N个人K排的队形设计排队规则如下:
每排人数为N/K(向下取整),多出来的人全部站在最后一排;
后排所有人的个子都不比前排任何人矮;
每排中最高者站中间(中间位置为m/2+1,其中m为该排人数,除法向下取整);
每排其他人以中间人为轴,按身高非增序,先右后左交替入队站在中间人的两侧(例如5人身高为190、188、186、175、170,则队形为175、188、190、186、170。这里假设你面对拍照者,所以你的左边是中间人的右边);
若多人身高相同,则按名字的字典序升序排列。这里保证无重名。
现给定一组拍照人,请编写程序输出他们的队形。
输入格式:
每个输入包含1个测试用例。每个测试用例第1行给出两个正整数N(<=10000,总人数)和K(<=10,总排数)。随后N行,每行给出一个人的名字(不包含空格、长度不超过8个英文字母)和身高([30, 300]区间内的整数)。
输出格式:
输出拍照的队形。即K排人名,其间以空格分隔,行末不得有多余空格。注意:假设你面对拍照者,后排的人输出在上方,前排输出在下方。
IDEA:
自己写了一部分,有一部分是借鉴别人的
1. 用字符串连接每个要输出的名字,包括中间的空格;
2.身高从递增排列,使用字符串+“\n”实现:result=line+"\n"+result;//精华!!!
3.用 j%2!=end%2 判断是放在中间字符串的左边还是右边
CODE:
每排人数为N/K(向下取整),多出来的人全部站在最后一排;
后排所有人的个子都不比前排任何人矮;
每排中最高者站中间(中间位置为m/2+1,其中m为该排人数,除法向下取整);
每排其他人以中间人为轴,按身高非增序,先右后左交替入队站在中间人的两侧(例如5人身高为190、188、186、175、170,则队形为175、188、190、186、170。这里假设你面对拍照者,所以你的左边是中间人的右边);
若多人身高相同,则按名字的字典序升序排列。这里保证无重名。
现给定一组拍照人,请编写程序输出他们的队形。
输入格式:
每个输入包含1个测试用例。每个测试用例第1行给出两个正整数N(<=10000,总人数)和K(<=10,总排数)。随后N行,每行给出一个人的名字(不包含空格、长度不超过8个英文字母)和身高([30, 300]区间内的整数)。
输出格式:
输出拍照的队形。即K排人名,其间以空格分隔,行末不得有多余空格。注意:假设你面对拍照者,后排的人输出在上方,前排输出在下方。
IDEA:
自己写了一部分,有一部分是借鉴别人的
1. 用字符串连接每个要输出的名字,包括中间的空格;
2.身高从递增排列,使用字符串+“\n”实现:result=line+"\n"+result;//精华!!!
3.用 j%2!=end%2 判断是放在中间字符串的左边还是右边
CODE:
#include<iostream> #include<cstring> #include<vector> #include<algorithm> using namespace std; struct Stu{ string name; int height; }; int cmp(Stu s1,Stu s2){ if(s1.height==s2.height) return s1.name>s2.name; return s1.height<s2.height; }//从小到大排序 /* bool operator<(const Stu & s1,const Stu &s2) { if (s1.height!=s2.height) return s1.height<s2.height; return s1.name>s2.name; }*/ int main(){ int n,k; cin>>n>>k; vector<Stu> vec; string result=""; for(int i=0;i<n;i++){ Stu stu; cin>>stu.name>>stu.height; vec.push_back(stu); } sort(vec.begin(),vec.end(),cmp); /* for(it=vec.begin();it!=vec.end();it++){ cout<<(*it).name<<" "<<(*it).height<<endl; }*/ int w=n/k; for(int i=0;i<k;i++){ int begin=i*w; int end=i*w+w; if(end+w>n) end=n; string line=""; line=vec[end-1].name; for(int j=end-2;j>=begin;j--){ if(j%2!=end%2){ line=line+" "+vec[j].name;//放到后边 }else{ line=vec[j].name+" "+line;//放到前面 } } //cout<<line<<endl; result=line+"\n"+result;//精华!!! } cout<<result; return 0; }
相关文章推荐
- RadioGroup的多行显示RadioButton
- vs2013+cuda7.5+opencv3.1 将cu文件加入opencv工程问题记录
- Gremlin实现分析
- Android Studio ndk-Jni开发详细入门,Aes加密demo
- CCF 网络延时
- HTML4 和 HTML5 的10个关键区别
- iOS Xib关联错误导致的问题
- HDFS读写过程
- C#界面设计之谷歌地图下载并分块
- C++ 类的静态成员用法
- 7、大型重构
- C语言 32/64位机 数据类型字长
- avalon1与avalon2的异同点
- Redis命令-有序集合-zcard
- kvm快照功能
- 决心书
- centos6.4下配置nginx服务器更改根目录
- 剑指Offer-二维数组中的查找
- 算法_动态规划_电路布线
- 多层神经网络和BP反向传播算法Multilayer Networks and Backpropagation