1109 Group Photo

#include<iostream>

#include<vector>

#include<algorithm>

using namespace std;

int n,k;

struct node{

string name;

int height;

};

bool cmp(struct node a,struct node b){

return a.height!=b.height?a.height>b.height:a.name<b.name;

}

int main(){

cin>>n>>k;

int m;

vector<node>stu(n);

for(int i=0;i<n;i++){

cin>>stu[i].name;

cin>>stu[i].height;

}

sort(stu.begin(),stu.end(),cmp);

int t=0,row=k;//t是已处理的学生索引

//计算每行人数

while(row){

if(row==k){

m=n-n/k*(k-1);

}else{

m=n/k;

}

vector<string>ans(m);

ans[m/2]=stu[t].name;

//左边一列

int j=m/2-1;

for(int i=t+1;i<t+m;i=i+2){

ans[j--]=stu[i].name;

}

//右边一列

j=m/2+1;

for(int i=t+2;i<t+m;i=i+2){

ans[j++]=stu[i].name;

}

cout<<ans[0];

for(int i=1;i<m;i++){

cout<<" "<<ans[i];

}

cout<<endl;

t=t+m;//移动到下一批学生

row--;

}

return 0;

}

相关推荐
SunkingYang2 小时前
MFC中事件与消息有什么关联,区别与联系
c++·mfc·消息·事件·区别·联系·关联
未来之窗软件服务2 小时前
幽冥大陆(五十八)php1024位密码生成—东方仙盟筑基期
开发语言·算法·仙盟创梦ide·东方仙盟
青山是哪个青山2 小时前
第二节:CMake 命令行工具与工程生命周期
c++·cmake
不解风水2 小时前
【教程笔记】KalmanFilter
笔记·学习·算法·矩阵·ekf
ozyzo2 小时前
局部变量和全局变量
c++
2401_841495642 小时前
【数据结构】最短路径的求解
数据结构·动态规划·贪心·ipython·最短路径·迪杰斯特拉算法·弗洛伊德算法
西安同步高经理2 小时前
秒表实现自动化测量助力时频测量行业发展、秒表检定仪、毫秒表测量仪
人工智能·算法
夏幻灵2 小时前
C++ 里 什么时候不用指针,而选择值拷贝/深拷贝 ?
开发语言·c++·算法
这猪好帅2 小时前
【算法】动态规划 - 数字三角形模型
算法·动态规划