欢迎查看原题地址

此题思路(最初版):

暴力,得出最相近的,1000ms呢,除非数据超大,否则不超时。

说明:
爆搜,搜出结果,时间复杂度基本 $O(n^2)$

注:本文所有时间(与空间)复杂度仅为估计,不排除坑爹数据卡大复杂度的可能

#include <bits/stdc++.h>
using namespace std;
bool kkk(int a,int k) {
int tmp = abs(a);
//cout<<"data:"<<tmp<<"k:"<<k<<endl;
if(tmp<k) {
return 1;
} else {
return 0;
}
}
int main() {
long long n,m;
long long a[100001],b[10001];
cin>>n;
for(int i = 0;i<n;++i) {
cin>>a[i];
}
cin>>m;
for(int i = 0;i<m;++i) {
int k;
cin>>k;
int mink = 2345678;
int minv = 2345678;
for(int j = 0;j<max(n,m);++j) {
if(k-a[j]==0) {
minv = a[j];
break;
}
if(kkk(k-a[j],mink)) {
mink = k-a[j];
minv = a[j];
}
}
cout<<minv<<endl;
}
return 0;
}

详细提交代码:点击查看

详细提交结果:

测试数据共20组:

$\color{green}{AC}$ 6组

$\color{navy}{TLE}$ 14组

$\color{red}\text{总得分:30}$

于是,我开始探究为什么没过。。。


经研究表明:有一部分数据很大,一般的暴力水过是困难(难上加难)了,与其纠结所谓“怎么水过多骗骗分”还不如花一点时间想想正解,终于,功夫不负有心人,我找到了upper_bound()

先看看他的用法:

#include <bits/stdc++.h>
using namespace std;
int main() {
int a[10] = {1,2,3,4,5,6,11,12,13,14};
int b,c;
b = upper_bound(a,a+10,7)-a;
cout<<a[b]<<endl;
return 0;
}

这是实例,暂时不提供运行结果。

那么我们不难想到使用upper_bound()查找不小于这个数的最大数那么。。。

有两种情况:

设不小于这个数的最大数 = a;

一种:a==n

二种:a< n

那么就出来了这段代码:

#include <bits/stdc++.h>
using namespace std;
int kkk(int a,int b,int k) {
int tmp1 = abs(k-a);
int tmp2 = abs(k-b);
if(tmp1==0) {
return a;
}
if(tmp2==0) {
return b;
}
if(tmp2>tmp1){
return a;
} else {
return b;
}
}
int main() {
long long n,m;
long long a[100001];
cin>>n;
for(int i = 0;i<n;++i) {
cin>>a[i];
}
sort(a,a+n);
cin>>m;
for(int i = 0;i<m;++i) {
int m;
cin>>m;
int j = upper_bound(a,a+n,m)-a;
int k = j-1;
//cout<<a[j]<<" "<<a[k]<<" "<<m<<endl;
cout<<kkk(a[j],a[k],m)<<endl;
}
return 0;
}

详细提交代码:点击查看

详细提交结果:

测试数据共20组:

$\color{green}{AC}$ 20组

$\color{green}\text{总得分:100}$

折腾笔记-计蒜客t1156AC记的更多相关文章

  1. 折腾笔记-计蒜客T1167AC记

    查看原题 原题地址 思路: 判断回文+判断质数 初步代码: #include <bits/stdc++.h> using namespace std; bool prime(int n) ...

  2. 折腾笔记-计蒜客T1158-和为给定数AC记

    欢迎查看原题 1.简单题目叙述 蒜头君给出若干个整数,询问其中是否有一对数的和等于给定的数. 输入格式 共三行: 第一行是整数 ),表示有 n 个整数. 第二行是 n 个整数.整数的范围是在 0 到  ...

  3. 计蒜客T1846AC记

    查看原题: 原题地址 初步思路: 采用贪心法求解,贪心策略如下: 排序,优先买最便宜的. 累加总数ans 初步代码: (楼主评语:其实其他地方的编程实现不太重要,贪心策略才是问题) #include ...

  4. 计蒜客 NOIP 提高组模拟竞赛第一试 补记

    计蒜客 NOIP 提高组模拟竞赛第一试 补记 A. 广场车神 题目大意: 一个\(n\times m(n,m\le2000)\)的网格,初始时位于左下角的\((1,1)\)处,终点在右上角的\((n, ...

  5. [计蒜客] 矿石采集【记搜、Tarjan缩点+期望Dp】

    Online Judge:计蒜客信息学3月提高组模拟赛 Label:记搜,TarJan缩点,树状数组,期望Dp 题解 整个题目由毫无关联的两个问题组合成: part1 问题:对于每个询问的起点终点,求 ...

  6. 计蒜客 作弊揭发者(string的应用)

    鉴于我市拥堵的交通状况,市政交管部门经过听证决定在道路两侧安置自动停车收费系统.当车辆驶入车位,系统会通过配有的摄像头拍摄车辆画面,通过识别车牌上的数字.字母序列识别车牌,通过连接车管所车辆信息数据库 ...

  7. 计蒜客的一道题dfs

    这是我无聊时在计蒜客发现的一道题. 题意: 蒜头君有一天闲来无事和小萌一起玩游戏,游戏的内容是这样的:他们不知道从哪里找到了N根不同长度的木棍, 看谁能猜出这些木棍一共能拼出多少个不同的不等边三角形. ...

  8. 计蒜客模拟赛5 D2T1 成绩统计

    又到了一年一度的新生入学季了,清华和北大的计算机系同学都参加了同一场开学考试(因为两校兄弟情谊深厚嘛,来一场联考还是很正常的). 不幸的是,正当老师要统计大家的成绩时,世界上的所有计算机全部瘫痪了. ...

  9. 计蒜客 等边三角形 dfs

    题目: https://www.jisuanke.com/course/2291/182238 思路: 1.dfs(int a,int b,int c,int index)//a,b,c三条边的边长, ...

随机推荐

  1. MyBatis(4)-- 动态SQL

    如果使用JDBC或者类似于Hibernate的其他框架,很多时候要根据需要去拼装SQL,这是一个麻烦的事情.因为某些查询需要许多条件.通常使用其他框架需要大量的Java代码进行判断,可读性比较差,而M ...

  2. OptimalSolution(4)--字符串问题(2)进阶

    一.将整数字符串转成整数值 二.判断字符数组中是否所有的字符都只出现过一次 三.在有序但含有空的数组中查找字符串 四.数组中两个字符串的最小距离 五.添加最少字符使字符串整体都是回文字符串 六.括号字 ...

  3. UART和RS232/RS485的关系是什么?

    串口通讯是电子工程师和嵌入式开发工程师面对的最基本问题,RS232则是其中最简单最常用的通讯方式.但是初学者往往搞不清有关的名词如UART和RS232或RS485之间是什么关系,因为它们经常被放到语句 ...

  4. ansible剧本之playbook操作

    ansible 剧本 yaml介绍: 是一个编程语言 文件后缀名 yaml yml 数据对应格式: 字典: key: value 列表: [] - ansible-playbook命令格式 执行顺序: ...

  5. node 短信接口的调用

    首先安装一下 短信的sdk 依赖 这里使用的是阿里云的短信SDK,在阿里云官网申请 npm install @alicloud/sms-sdk --save 调用 新建个 message.js /** ...

  6. springboot---发送邮件

    1.pom.xml配置 <dependencies> <dependency> <groupId>org.springframework.boot</grou ...

  7. 配置Docker镜像加速

    1.在docker toolbox执行下面的命令进入VM bash docker-machine ssh default 2.执行下面的命令修改profile文件: sudo vi /var/lib/ ...

  8. Linux性能分析

    生产环境服务器变慢,诊断思路和性能评估 整机:top 代码 public class JavaDemo2 { public static void main(String[] args) { whil ...

  9. 以Mnist为例从头开始自己建立数据集,搭建resnet34,识别Mnist

    写在前面: 本人小白研一,刚开始学习深度学习,将自己的第一个实验过程总结下来,看了很多的大牛的博客,在下面的程序中也参考了很多大牛的博客.在刚开始入门的学习的时候,直接编写程序下载数据集,但是后来觉得 ...

  10. OV5640摄像头的数据处理配置流程(一)

    module RGB_init( //系统信号输入(时钟+复位) input cmos_clk_i, //模块控制时钟 input rst_n_i, //系统复位信号 //OV5640输出信号(从56 ...