折腾笔记-计蒜客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三条边的边长, ...
随机推荐
- Leetcode Tags(3)String(TODO)
一.Easy 696 Count Binary Substrings Input: "00110011" Output: 6 Explanation: There are 6 su ...
- 数据结构(二十七)Huffman树和Huffman编码
Huffman树是一种在编码技术方面得到广泛应用的二叉树,它也是一种最优二叉树. 一.霍夫曼树的基本概念 1.结点的路径和结点的路径长度:结点间的路径是指从一个结点到另一个结点所经历的结点和分支序列. ...
- UnityWebRequest_ZT
using System; using System.Collections; using System.Collections.Generic; using UnityEngine; using U ...
- marquee滚动标签
marquee语法 <marquee></marquee> 实例一<marquee>Hello, World</marquee> marquee常 ...
- (IDEA) 搭建Maven并使用Maven打包部署
1.配置Maven的环境变量 a.首先我们去maven官网下载Maven程序,解压到安装目录,如图所示: b.配置M2_HOME的环境变量,然后将该变量添加到Path中 备注:必须要有JAVA_HOM ...
- 给自己网站配置 https,http2 ,gzip压缩
https 需要购买域名ssl证书 注意事项: 1.要开启HTTP/2协议支持,需要在nginx 1.10以上版本并且需要openssl库的版本在1.0.2及以上编译. 2.http2.0只支持开启了 ...
- Python实现王者荣耀小助手(一)
简单来说网络爬虫,是指抓取万维网信息的程序或者脚本,Python在网络爬虫有很大优势,今天我们用Python实现获取王者荣耀相关数据,做一个小助手: 前期准备,环境搭建: Python2.7 sys模 ...
- linux shell脚本语法笔记
1.&,&&,|,|| &:除了最后一个cmd,前面的cmd均已后台方式静默执行,执行结果显示在终端上,个别的cmd错误不影响整个命令的执行,全部的cmd同时执行 &a ...
- linux下的压缩解压命令
.gz解压1:gunzip FileName.gz解压2:gzip -d FileName.gz压缩:gzip FileName .tar.gz 和 .tgz解压:tar zxvf FileName. ...
- Microsoft Visual C++ 14.0 is required问题解决
当我们在windows下安装包或者软件时会出现: Microsoft Visual C++ b'v14.0 is required 错误解决办法 直接下载安装visualstudio: https:/ ...