【9210】找礼物(char* num[2000]的使用 get char num[i] = new char[1000])
Time Limit: 10 second
Memory Limit: 2 MB
问题描述
新年到了,突然间,就在那美丽的一霎那,你好友和你(K个人)的周围满是礼物,你发扬你帅气的风格,让你的好友先拿,但是每个人只能拿当前离自己最近的礼物[当然如果有并列的多个礼物离你的距离相等(精确到小数后四位,所有运算均为去尾),这些礼物就都属于这个人]。现在你们所在的位置是原点(0,0),每个礼物的位置用坐标表示。现在告诉你每个礼物的坐标,还有每个礼物是谁送的。要你找出你的礼物离你多远,你能拿到多少礼物,这些礼物是谁送的。如果你拿不到礼物,请输出“555…”
Input
第一行:N 和 K 分别表示礼物的个数和人数。
第二到N+1行:每行先是赠送礼品人的姓名,然后是礼物的坐标(x,y)。
数据间空格分割
Output
第一行: D 和 U 表示礼物距你多远(只要去尾后的整数)和你能拿到多少礼物。
第二到U+1行:每行一个人名,表示送礼的人。<按照输入的顺序输出>
Sample Input
10 2
Pos 18426 3429
Kill -28989 -12602
WGPO -6095 11806
EhiEN 4 -3
DICV 7752 -27723
FBI 15713 -24074
QOHR -3194 -30639
WWJ 3 4
GKIX -5 0
CB 0 2
Sample Output
5 3
EhiEN
WWJ
GKIX
【题解】
保留4位的方法是 floor( sqrt(x*x + y*y) * 10000)/10000;存入数组中,以距离为关键字进行升序排。然后先给其他的小伙伴分,最后剩下自己的,在输入数据的时候记录每个礼物出现的先后顺序,最后输出的时候对自己要输出的礼物按照出现的顺序再排一次序。最后输出就好。这里的double类可以直接用“==”判断两个数是否相等。前面输入字符串的时候,用了char* name[90000] 这个东西,在输入之前要getchar一下,然后是num[i] = new char[1000],之后就能用scanf("%s")来进行输入了,会遇到空格停止。所以可以直接一排输入scanf("%s%lf%lf"),当然这是从别人那里挖过来的。用cin会超时。
【代码】
#include <cstdio>
#include <iostream>
#include <string>
#include <cmath>
#include <stdlib.h> using namespace std; struct data
{
double dis;
int first;
}; int n,k;
data a[90000];
char* name[90000]; //要记住这个输入字符串的写法 void input_data()
{
scanf("%d %d",&n,&k);
int m = 0;
getchar(); //在用之前要先getchar一下。
for (int i = 1;i <= n;i++)
{
name[i] = new char[1000]; //记住 new char [长度]
double x,y;
scanf("%s%lf%lf",name[i],&x,&y); //就可以直接用“%s"来进行输入了
a[i].dis = floor( sqrt(x*x + y*y) * 10000)/10000; //floor是取整函数
a[i].first = ++m; //记录下每个礼物出现的先后顺序
}
} void kp(int l,int r) //以距离为关键字进行从小到大排
{
int i = l,j = r;
double m = a[(i+j)/2].dis;
do
{
while (a[i].dis < m) i++;
while (m < a[j].dis) j--;
if (i <= j)
{
a[0] = a[i];a[i] = a[j];a[j] = a[0]; //与之相关的所有东西 都要进行变换
name[0] = name[i];name[i] = name[j];name[j] = name[0];
i++;j--;
}
}
while (i <= j);
if (l < j) kp(l,j);
if (i < r) kp(i,r);
} void kp2(int l,int r) //以出现的先后顺序为关键字 进行从小到大排序
{
int i = l,j = r,m = a[(i+j)/2].first;
do
{
while (a[i].first < m) i++;
while (m < a[j].first) j--;
if (i <= j)
{
a[0] = a[i];a[i] = a[j];a[j] =a[0];
name[0] = name[i];name[i] = name[j];name[j] = name[0];
i++;j--;
}
}
while (i <=j );
if (l < j) kp2(l,j);
if (i < r) kp2(i,r);
} void get_ans()
{
k--; //k包括自己 我们先减去自己 处理其他人
kp(1,n);
int i = 1;
while (k > 0 && i <= n) //先过滤掉别人的礼物
{
int j = i+1;
while ( a[j].dis == a[i].dis) j++;
i = j;
k--;
}
if (k > 0) //如果别人都没分完则自己不可能有剩余礼物。但是好像有问题。。。如果别人刚好分完了呢?我在下面加几行。
{
printf("555…");
return;
}
if (k == 0 && i > n)
{
printf("555…");
return;
}
int j = i+1;
while ( a[j].dis == a[i].dis) j++;//然后找哪些礼物是自己的。
int dd = int(a[i].dis); //直接取整就好
printf("%d %d\n",dd,j-i);
kp2(i,j-1); //对自己的礼物以出现的先后顺序进行排序。
for (int kk = i;kk <=j-1;kk++)
printf("%s\n",name[kk]);
} int main()
{
//freopen("F:\\rush.txt","r",stdin);
input_data();
get_ans();
return 0;
}
【9210】找礼物(char* num[2000]的使用 get char num[i] = new char[1000])的更多相关文章
- 找礼物(find)
找礼物(find) 题目描述 新年到了,你的好友和你(共K个人)的周围满是礼物,你让你的好友先拿,但是每个人只能拿当前离自己最近的礼物[当然如果有并列的多个礼物离你的距离相等(精确到小数点后四位,所有 ...
- 找礼物(find)(模拟)
找礼物(find) 时间限制: 1 Sec 内存限制: 64 MB提交: 57 解决: 4[提交][状态][讨论版] 题目描述 新 年到了,你的好友和你(共K个人)的周围满是礼物,你让你的好友先拿 ...
- C# 将long类型写入二进制文件用bw.Write(num);将其读出用long num= br.ReadInt64();
理由: 因为long类型是 System.Int64 (长整型,占 8 字节,表示 64 位整数,范围大约 -(10 的 19) 次方 到 10 的 19 次方) 而long BinaryReader ...
- c语言个人财务管理系统
这个是我的一个网上朋友写的,仅供大家参考: 在这里留个记录 #include<stdio.h>#include<string.h>#define null 0#define m ...
- TIME_WAIT引起Cannot assign requested address报错
1. 问题描述 有时候用redis客户端(php或者java客户端)连接Redis服务器,报错:"Cannot assign requested address." 原因是客户端 ...
- Oracle数据库(一)概述、基础与简单操作
数据库: 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库. 数据库分类: 关系型数据库 非关系型数据库 数据库 类型 特性 优点 缺点 关系型数据库 SQLite.Oracle. ...
- vue 基础(一)
一 vue.js的M-V-VM思想 MVVM 是Model-View-ViewModel 的缩写,它是一种基于前端开发的架构模式. 1.Model指代的就是vue对象的data属性里面的数据.这里的数 ...
- Java语言基础(9)
1 方法(二) 1) 不带参数没有返回值的方法: 案例:Demo1 public class Demo1 { static void show(){ System.out.println(" ...
- 谈谈 char *num="123";和char num[4]="123";的区别
最近写程序的时候发现这样一个问题 #include<iostream> #include <string.h> using namespace std; void revers ...
随机推荐
- SpringMVC学习总结(2)——SpringMVC返回json配置
<!-- 避免IE执行AJAX时,返回JSON出现下载文件 --> <bean id="mappingJacksonHttpMessageConverter" c ...
- 机房收费 & 廊院食堂
做机房收费系统时.常常想这个一般用户指的是谁?我当初以为是学生......可能是被数据库中的student带跑偏了...... 事实上把我们的系统联系一下实际,就会非常easy想到一般用户指的是谁的位 ...
- 关于腾讯云server使用FTP具体配置教程
本文文件夹:-------------------------------------------------------- [-] 腾讯云server介绍 关于腾讯云server使用感受 作为开发人 ...
- js进阶 13-9/10 jquery如何实现三级列表
js进阶 13-9/10 jquery如何实现三级列表 一.总结 一句话总结:用的是定位,父标签相对定位,子标签就可以绝对定位了,绝对定位的孩子还是可以设置绝对定位.用toggle设置子菜单显示和隐藏 ...
- amazeui-datatables(登录注册界面用到)
amazeui-datatables(登录注册界面用到) 一.总结 amazeui-datatables:DataTables 插件 Amaze UI 集成,只修改了样式和默认显示语言,其他参数同官方 ...
- 并发控制MsSql
Isolation 阅读目录(Content) 1 并发控制理论 1.1 悲观并发控制 1.2 乐观并发控制 2 隔离级别 2.1 隔离级别说明 2.2 Read Commmitted Snaps ...
- css结构设计思想
本文摘自博客园-予沁安的文章:结构化CSS设计思维,作为学习笔记记录一下 1.LESS.SASS等预处理器给CSS开发带来了语法的灵活和便利,其本身却没有给我们带来结构化设计思维.很少有人讨论CSS的 ...
- JS错误记录 - 取消事件冒泡、按钮、回车、ctrl回车提交留言
window.onload = function () { var oDiv = document.getElementById('div1'); var oBtn = document.getEle ...
- PythonNET网络编程1
# PythonNET 网络编程 ISO(国际标准化组织) 制定了 OSI(Open System Interconnectio),意为开放式系统互联.国际标准化组织(ISO)制定了OSI模型,该模型 ...
- 【Codeforces Round #301 (Div. 2) B】 School Marks
[链接] 我是链接,点我呀:) [题意] 已知k门成绩. 总共有n门成绩. 让你构造剩下的n-k门成绩,使得这n门成绩的中位数>=y,并且这n门成绩的和要小于等于x. n为奇数 [题解] 首先判 ...