折腾笔记-计蒜客t1156AC记
欢迎查看原题地址
此题思路(最初版):
暴力,得出最相近的,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记的更多相关文章
- 折腾笔记-计蒜客T1167AC记
查看原题 原题地址 思路: 判断回文+判断质数 初步代码: #include <bits/stdc++.h> using namespace std; bool prime(int n) ...
- 折腾笔记-计蒜客T1158-和为给定数AC记
欢迎查看原题 1.简单题目叙述 蒜头君给出若干个整数,询问其中是否有一对数的和等于给定的数. 输入格式 共三行: 第一行是整数 ),表示有 n 个整数. 第二行是 n 个整数.整数的范围是在 0 到 ...
- 计蒜客T1846AC记
查看原题: 原题地址 初步思路: 采用贪心法求解,贪心策略如下: 排序,优先买最便宜的. 累加总数ans 初步代码: (楼主评语:其实其他地方的编程实现不太重要,贪心策略才是问题) #include ...
- 计蒜客 NOIP 提高组模拟竞赛第一试 补记
计蒜客 NOIP 提高组模拟竞赛第一试 补记 A. 广场车神 题目大意: 一个\(n\times m(n,m\le2000)\)的网格,初始时位于左下角的\((1,1)\)处,终点在右上角的\((n, ...
- [计蒜客] 矿石采集【记搜、Tarjan缩点+期望Dp】
Online Judge:计蒜客信息学3月提高组模拟赛 Label:记搜,TarJan缩点,树状数组,期望Dp 题解 整个题目由毫无关联的两个问题组合成: part1 问题:对于每个询问的起点终点,求 ...
- 计蒜客 作弊揭发者(string的应用)
鉴于我市拥堵的交通状况,市政交管部门经过听证决定在道路两侧安置自动停车收费系统.当车辆驶入车位,系统会通过配有的摄像头拍摄车辆画面,通过识别车牌上的数字.字母序列识别车牌,通过连接车管所车辆信息数据库 ...
- 计蒜客的一道题dfs
这是我无聊时在计蒜客发现的一道题. 题意: 蒜头君有一天闲来无事和小萌一起玩游戏,游戏的内容是这样的:他们不知道从哪里找到了N根不同长度的木棍, 看谁能猜出这些木棍一共能拼出多少个不同的不等边三角形. ...
- 计蒜客模拟赛5 D2T1 成绩统计
又到了一年一度的新生入学季了,清华和北大的计算机系同学都参加了同一场开学考试(因为两校兄弟情谊深厚嘛,来一场联考还是很正常的). 不幸的是,正当老师要统计大家的成绩时,世界上的所有计算机全部瘫痪了. ...
- 计蒜客 等边三角形 dfs
题目: https://www.jisuanke.com/course/2291/182238 思路: 1.dfs(int a,int b,int c,int index)//a,b,c三条边的边长, ...
随机推荐
- Java基础(一)对象构造
由于Java对象构造非常重要,所以Java提供了多种编写构造器的机制. 1.重载 如果多个方法有相同的名字.不同的参数,便产生了重载.编译器必须挑选出具体执行哪个方法,它通过用各个方法给出的参数类型与 ...
- LeetCode 二叉树的层次遍历
第102题 给定一个二叉树,返回其按层次遍历的节点值. (即逐层地,从左到右访问所有节点). 例如: 给定二叉树: [3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 ...
- mha格式的CT体数据转为jpg切片
mha格式的CT体数据转为jpg切片 mha格式 .mha文件是一种体数据的存储格式,由一个描述数据的头和数据组成,一般我们拿到的原始医学影像的数据是.dcm也就是dicom文件,dicom文件很复杂 ...
- 网络安全-主动信息收集篇第二章-二层网络扫描之arping
arping二层网络发现 介绍工具:arping arping主要查看IP的MAC地址 缺点:工具本身只能ping一个IP地址,不能ping一个IP段.但是可以通过脚本将整个网络中的IP进行扫描. 脚 ...
- VirtualBox6安装CentOS7设置静态IP
安装virtualbox后安装centos7, 这里就不在赘述了, 网上有很多教程 先关闭虚拟机, 按照如下设置配置网络 这里需要使用双网卡, 我们在开启第二个网卡, 如下所示 之后开启虚拟机, 进行 ...
- 【并发编程】ThreadLocal其实很简单
什么是ThreadLocal ThreadLocal有点类似于Map类型的数据变量.ThreadLocal类型的变量每个线程都有自己的一个副本,某个线程对这个变量的修改不会影响其他线程副本的值.需要注 ...
- 命运Ⅰ&命运Ⅱ
upd:为啥下面的相关博文都是各种退役记(这TM怎么就相关了) 竟然被卡线了,16名,我这几次考试也是炸到了一定境界了... 前三次模拟总榜rk1,第一次分机房rk4,第二次分机房rk11,第三次分机 ...
- 欧拉路&&欧拉回路
T1是欧拉路板子,但我不会,直接爆炸.. 这玩意就是个dfs,但我以前一直以为欧拉路只能$O(nm)$求 今天才知道可以$O(n+m)$ 欧拉路判定: 无向:起点终点为奇度点,其余偶度 有向:起点终点 ...
- 原生JS实现栈结构
1. 前言 栈,是一种遵从后进先出(LIFO,Later-In-First-Out)原则的有序集合.新添加的元素都保存在栈的一端,称作栈顶,另一端叫做栈底.在栈中,新元素都靠近栈顶,旧元素都靠近栈底. ...
- 大数据之路week01--day02_2 集合方面的总结
(初稿 太晚了,明天再进行补充) 1.对象数组(掌握) (1)数组既可以存储基本数据类型,也可以存储引用类型.它存储引用类型的时候的数组就叫对象数组. (2)案例: 用数组存储5个学生对象,并遍历数组 ...