FJUT-1370 记录一次解题过程
- 题目在福工院的1370
首先看题目,好家伙,全英文
那么大致的题意就是。有几个城市同在一条线上(相当于在x轴上),max i是第i个城市到其他所有城市的距离中的最大值,min i也就是所有中最小的。
再看输入
第一行输入一个n(2 ≤ n ≤ 105),代表城市数量。第二行有n个数:x1, x2, ..., xn ( - 109 ≤ xi ≤ 109),代表每个城市的横坐标。
看一下输出
输出n行,每行输出两个数,代表第i个城市到其他所有城市的距离最小值min i、最大值max i。
那么,这道题是想干什么呢?
就是给你n个在x轴上的点,x坐标告诉你了,求每个点距离其他点的最小值与最大值。
读懂了题,那就比较好写了。
首先读入每个城市横坐标
for(i=; i<n; i++) {
cin>>x[i];
}
然后接下来分别求出每个max、min就可以了
for(i=; i<n; i++) {
int max=;
int min=inf;
for(j=; j<n; j++) {
if(abs(x[i]-x[j])>max&&i!=j)
max=abs(x[i]-x[j]);
if(abs(x[i]-x[j])<min&&i!=j)
min=abs(x[i]-x[j]);
}
cout<<min<<" "<<max<<endl;
}
inf在函数外定义为0x3f3f3f3f,代表无穷大。这里的思路就是:你要比每个点到其他点的距离,那就先定一个点,让这个点与其他的点比较,这就有了上面的内层for循环。
max初始值为0,min初始值无穷大,定的点初始为第一个点,把它与第二个点比较,那么距离为3,而这个3大于初始的max,那新的max就变成了3。3小于初始的min,拿新的min就为3。然后再拿定点和下一个点比较,距离为7,大于max,故新的max为7,不小于min,故min还是3。以此类推,最后这个定点距其他所有点的min就为3,max就为12。
然后我们就需要设置第二个点、第三个点······为定点来比较了,因此就有了外层的for循环。
上面的代码中,if判断里有i!=j,这是为了避免定点与定点相比,否则相比之后,得出距离为0,那么最后它的min值就会为0,是错的。
那么完整的代码奉上(由于用了for嵌套,怕卡时间,就取消了共用缓冲区,代码为 int main() { 下面的那两行)
#include<bits/stdc++.h>
using namespace std;
#define inf 0x3f3f3f3f
int x[];
int main() {
ios_base::sync_with_stdio(false);
cin.tie();
int n,i,j;
cin>>n;
for(i=; i<n; i++) {
cin>>x[i];
}
for(i=; i<n; i++) {
int max=;
int min=inf;
for(j=; j<n; j++) {
if(abs(x[i]-x[j])>max&&i!=j)
max=abs(x[i]-x[j]);
if(abs(x[i]-x[j])<min&&i!=j)
min=abs(x[i]-x[j]);
}
cout<<min<<" "<<max<<endl;
}
return ;
}
如果你提交这段代码,那么恭喜您喜提一个wa,至于原因我还没找到。这又是一道英文题,无法找网上的代码来借鉴。于是没办法,只有再写咯。其实写这段找min、max前,我的第一个思路是,因为这几个点都是按坐标顺序排着的,那么只用在它的位置上花功夫不就ok了吗。但当时感觉两个for循环找更稳,就没有细想。
那么从位置上来,需要考虑的就是两个东西。
首先。第一个点,它的max值一定是和最后一个点的差,min值一定是和第二个点的差。最后一个点也是这样,max值是和第一个点的差,min值是和倒数第二个点的差。
其次。中间的点的min值,一定是和相邻的点的差,需要找的就是到底是左边还是右边。max值一定是和第一个点或最后一个点的差。
那么如何找 到底是左边还是右边相邻点离中间点的距离更小?到底是第一个还是最后一个点离中间点距离更大?事实上,把要比较的两个值直接放入min() max()函数就ok啦。
cout<<x[]-x[]<<" "<<x[n-]-x[]<<endl;
for(i=; i<n-; i++)
cout<<min(x[i]-x[i-],x[i+]-x[i])<<" "<<max(x[i]-x[],x[n-]-x[i])<<endl;
cout<<x[n-]-x[n-]<<" "<<x[n-]-x[]<<endl;
显而易见,第一个点和最后一个点单独拿出来手动输出,中间的点,直接比较就ok
完整代码
#include<bits/stdc++.h>
using namespace std;
int x[];
int main() {
int n,i;
cin>>n;
for(i=; i<n; i++)
cin>>x[i];
cout<<x[]-x[]<<" "<<x[n-]-x[]<<endl;
for(i=; i<n-; i++)
cout<<min(x[i]-x[i-],x[i+]-x[i])<<" "<<max(x[i]-x[],x[n-]-x[i])<<endl;
cout<<x[n-]-x[n-]<<" "<<x[n-]-x[]<<endl;
return ;
}
ok ac
FJUT-1370 记录一次解题过程的更多相关文章
- 一个蒟蒻的解题过程记录——洛谷P1003 铺地毯
这到题算是我“火线回归”后码的第一道题,病好了心情不错,发篇博客分享一下 目录: ·题目描述 ·题目分析 ·解题思路 ·代码实现 ·总结 ·题目描述: 为了准备一场特殊的颁奖典礼,组织者在会场的一片矩 ...
- A+B Format 思路及解题过程结果
A+B Format 思路及解题过程结果 github链接 题目 解题思路 这个题目的难点在于每三位用逗号隔开,以及带不带负号的问题.第一个问题,我的解决办法是先通过取整来取数,再通过取余来去数.第二 ...
- CUDA 编程相关;tensorflow GPU 编程;关键知识点记录;CUDA 编译过程;NVCC
本文章主要是记录,cuda 编程过程中遇到的相关概念,名字解释和问题:主要是是用来备忘: cuda PTX :并行线程执行(Parallel Thread eXecution,PTX)代码是编译后的G ...
- 记录 Allsec 解题过程
开局打开URL:http://119.3.191.245:65532/#/allsecPlayGame,前去做游戏 游戏URL:http://119.3.191.245:8877/Login.php ...
- 记录visual Studio使用过程中的两个问题
Visual Studio是Windows平台下进行项目管理和开发的终极利器.除了微软自家的技术外,新版的VS不但支持Javascript, Python的开发调试,甚至还支持了Android, iO ...
- 动态规划:HDU1160-FatMouse's Speed(记录动态规划状态转移过程)
FatMouse's Speed Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- 记录IOS入门的过程
先说点私话.再进入正题吧,顺便抒发下情绪.公司传统业务不景气,而互联网正如火如荼,无奈被逼上梁山.開始学起了IOS编程.后来想想闲着也是闲着就学习学习呗.无奈公司确实不希望投入了.不愿意提供苹果电脑. ...
- iscc2016 mobile1-TurtleShell.apk解题过程
拿到程序先运行,简单的验证输入的flag正确与否.jeb加载apk文件 实在库文件里面验证,所以ida加载之,so文件是加密的,所以看不到关键验证函数,百度搜了下libhackme.so,出来这篇文章 ...
- PAT----1001. A+B Format (20)解题过程
1001. A+B Format (20) github链接 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B Calculate a + b and output t ...
随机推荐
- 下推栈实现(c++编程思想 p136)
1 头文件Stack.h #ifndef STACK_H #define STACK_H struct Stack { struct Link { void* data; Link* next; vo ...
- win10 uwp 在 Canvas 放一个超过大小的元素会不会被裁剪
我尝试在一个宽度200高度200的 Canvas 放了一个宽度 300 高度 300 的元素,这个元素会不会被 Canvas 裁剪了? 经过我的测试,发现默认是不会被裁剪 火火问了我一个问题,如果有一 ...
- 【9101】求n!的值
Time Limit: 10 second Memory Limit: 2 MB 问题描述 用高精度的方法,求n!的精确值(n的值以一般整数输入). Input 文件输入仅一行,输入n. Output ...
- .net连接数据库
/* 连接数据库步骤-- 1.创建连接字符串 data source = ... 计算机名称 initial catalog = ... 数据库名称 integrated security = tru ...
- H3C VLAN配置示例
- linux 重用 short 为 I/O 内存
short 例子模块, 在存取 I/O 端口前介绍的, 也能用来存取 I/O 内存. 为此, 你必须告 诉它使用 I/O 内存在加载时; 还有, 你需要改变基地址来使它指向你的 I/O 区. 例如, ...
- ASP.NET MVC 实现页落网资源分享网站+充值管理+后台管理(9)之系统登录
前面我们已经做好了一个文章管理功能模块,接下来,我们回头来做登录窗口,登录不仅涉及到登录验证还涉及到登录日志还有缓存时长等. 对于缓存的相关设置,我们已经写好封装在Bobo.Utilities.dll ...
- 一道非常棘手的 Java 面试题:i++ 是线程安全的吗
转载自 一道非常棘手的 Java 面试题:i++ 是线程安全的吗 i++ 是线程安全的吗? 相信很多中高级的 Java 面试者都遇到过这个问题,很多对这个不是很清楚的肯定是一脸蒙逼.内心肯定还在质疑 ...
- SpringBoot --web 应用开发之文件上传
原文出处: oKong 前言 上一章节,我们讲解了利用模版引擎实现前端页面渲染,从而实现动态网页的功能,同时也提出了兼容jsp项目的解决方案.既然开始讲解web开发了,我们就接着继续往web这个方向继 ...
- 2019-8-31-C#-如何写-DEBUG-输出
title author date CreateTime categories C# 如何写 DEBUG 输出 lindexi 2019-08-31 16:55:58 +0800 2018-2-13 ...