ICPC World Finals 2018 Problem H Single Cut of Failure
解法概要:
问题可以转化为
考虑一个长为 $2n$ 的数组 $A$,$1$ 到 $n$ 这 $n$ 个整数每个恰在 $A$ 中出现 $2$ 次。判断是否存在一个长为 $n$ 的子段使得 $1$ 到 $n$ 在其中各出现一次。
这个经典问题可用双指针在 $O(n)$ 的时间内解决。
这道题我 WA 到死,不是因为思路有漏洞,而是因为我不了解 std::cout 。
什么是 IO manipulators
默认情况下,cout 输出浮点数的格式是 std::defaultfloat。
下面我们来看一下 defaultfloat 究竟是个什么东西。
defaultfloat 是一个 ios_base manipulator 。
那么 manipulator 是什么呢
IO manipulator are helper functions that make it possible to control input/output streams using
operator<<oroperator>>.The manipulators that are invoked without arguments (e.g.
std::cout << std::boolalpha;orstd::cin >> std::hex;) are implemented as functions that take a reference to a stream as their only argument.(e.g.std::fixedis declared asios_base& fixed(ios_base& str);)The special overloads ofbasic_ostream::operator<<andbasic_istream::operator>>accept pointers to these functions.The manipulators that are invoked with arguments (e.g.
std::cout << std::setw(10);) are implemented as functions returning objects of unspecified type. These manipulators define their ownoperator<<oroperator>>which perform the requested manipulation. Manipulators that take arguments are defined in theiomanipheader.
SOURCE
basic_ostream::operator<< 默认情况下如何输出浮点数
By default, floating-point values are printed using six digits of precision (
1.55printed as1.55,1.55667printed as1.55667,3.1415926printed as3.14159); the decimal point is omitted if the value has no fractional part (e.g.1.00is printed as1); trailing zeros are removed (e.g.1.5000printed as1.5); and they are printed in eighter fixed or scientific notation depending on the value of the number. The library chooses a format that enhances readability of the number. Very large and very small values are printed using scientific notation. Other values are printed in fixed decimal.
总结:
默认情况下(对应于 manipulator std::defaultfloat),basic_ostream::operator<< 输出浮点数的格式为:
最多 6 位数字(整数部分和小数部分加起来共 6 位,术语为 precision 为 6),具体而言
- 若原本整数部分与小数部分位数之和就不超过 6 位,则原样输出,并去除 trailing zeros。
- 若整数部分不超过 6 位,则先四舍五入去除多出小数部分再去除 trailing zeros。
- 在上述两种情况中,若小数部分完全被去除,则小数点也不输出。
- 若整数部分超过 6 位,则用科学记数法。
std::setprecision(n) 与 std::fixed 的作用
setprecision(n) 的作用是将浮点数的输出精度 (precision) 设为 n。那么这里的 precision 究竟是什么意思呢?
By default, precision controls the total number of digits that are printed. When printed, floating-point values are rounded, not truncated, to the current precision. Thus, if the current precision is four, then
3.14159becomes3.142; if the precision is three, then it is printed as3.14.We can change precision by calling the precision by calling the
precisionmember (function) or by using thesetprecisionmanipulator. Theprecisionmember is overloaded. One version takes anintvalue and sets the precision to that new value. It returns the previous value. The other version takes no arguments and returns the current precision value. Thesetprecisonmanipulator takes an argument, which it uses to set the precision.
C++ Primer, 5th edition, pp 756
注意,这里所说的 “rounded to the current precision” 具体仍然是按上面总结的方法操作。
std::fixed 控制浮点数的记数方式(这里“记数方式”意思是“书写方式”,不是计数方式,也不是精度),std::fixed 使得浮点数始终按十进制格式(fixed decimal,不理解 fixed 在这里是什么意思;fixed decimal 与 scientific notation 相对)输出,也就是说较大的数或较小的数不用科学记数法了。
另外使用 fixed 这个 manipulator 之后,精度的含义也改变了。
These manipulators (
fixed,scientific,hexfloat) also change the default meaning of the precision for the stream. After executingscientific,fixed, orhexfloat, the precision value controls the number of digits after the decimal point. By default, precision specifies the total number of digits——both before and after the decimal point.
总结
如果题目中要输出浮点数,若指明保留几位小数(例如 4 位小数),则在 main 函数的开头加上一行
std::cout << std::fixed << std::setprecision(4);
若只写
std::cout << std::fixed;
就是保留 6 位小数。
Reference
ICPC World Finals 2018 Problem H Single Cut of Failure的更多相关文章
- 2020 ICPC Asia Taipei-Hsinchu Regional Problem H Optimization for UltraNet (二分,最小生成树,dsu计数)
题意:给你一张图,要你去边,使其成为一个边数为\(n-1\)的树,同时要求树的最小边权最大,如果最小边权最大的情况有多种,那么要求总边权最小.求生成树后的所有简单路径上的最小边权和. 题解:刚开始想写 ...
- HDU 6326.Problem H. Monster Hunter-贪心(优先队列)+流水线排序+路径压缩、节点合并(并查集) (2018 Multi-University Training Contest 3 1008)
6326.Problem H. Monster Hunter 题意就是打怪兽,给定一棵 n 个点的树,除 1 外每个点有一只怪兽,打败它需要先消耗 ai点 HP,再恢复 bi点 HP.求从 1 号点出 ...
- Codeforces Bubble Cup 8 - Finals [Online Mirror]H. Bots 数学
H. Bots Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/575/problem/H Desc ...
- Codeforces Gym 100610 Problem H. Horrible Truth 瞎搞
Problem H. Horrible Truth Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/1006 ...
- Western Subregional of NEERC, Minsk, Wednesday, November 4, 2015 Problem H. Parallel Worlds 计算几何
Problem H. Parallel Worlds 题目连接: http://opentrains.snarknews.info/~ejudge/team.cgi?SID=c75360ed7f2c7 ...
- ZOJ 4010 Neighboring Characters(ZOJ Monthly, March 2018 Problem G,字符串匹配)
题目链接 ZOJ Monthly, March 2018 Problem G 题意 给定一个字符串.现在求一个下标范围$[0, n - 1]$的$01$序列$f$.$f[x] = 1$表示存在一种 ...
- ZOJ 4009 And Another Data Structure Problem(ZOJ Monthly, March 2018 Problem F,发现循环节 + 线段树 + 永久标记)
题目链接 ZOJ Monthly, March 2018 Problem F 题意很明确 这个模数很奇妙,在$[0, mod)$的所有数满足任意一个数立方$48$次对$mod$取模之后会回到本身. ...
- 实验12:Problem H: 整型数组运算符重载
Home Web Board ProblemSet Standing Status Statistics Problem H: 整型数组运算符重载 Problem H: 整型数组运算符重载 Tim ...
- The Ninth Hunan Collegiate Programming Contest (2013) Problem H
Problem H High bridge, low bridge Q: There are one high bridge and one low bridge across the river. ...
随机推荐
- 【HHHOJ】NOIP模拟赛 玖 解题报告
点此进入比赛 得分: \(100+20+100=220\)(还不错) 排名: \(Rank\ 16\) \(Rating\):\(+20\) \(T1\):[HHHOJ263]「NOIP模拟赛 玖」三 ...
- Incorrect key file for table './xx_db/xx_table.MYI'; try to repair it
解决办法: 可以先运行 CHECK TABLE 表名 检查下是否存在错误. 然后运行 REPAIR TABLE 表名 进行修复.
- for循环语句中的先后执行顺序
for(int i=0;i<10;i++){ cout<<i; } 分析程序运行结果:for(cout<<"a";cout<<" ...
- 笔试算法题(46):简介 - 二叉堆 & 二项树 & 二项堆 & 斐波那契堆
二叉堆(Binary Heap) 二叉堆是完全二叉树(或者近似完全二叉树):其满足堆的特性:父节点的值>=(<=)任何一个子节点的键值,并且每个左子树或者右子树都是一 个二叉堆(最小堆或者 ...
- js函数带括号和不带括号赋给对象属性的区别
注意: 1.js为对象添加函数时,不要在函数后面加().一旦加了括号是表示将函数的返回值赋给对象的属性. 例:function test(){ document.writeln("我是js函 ...
- linux通配符知识
注意:linux通配符和三剑客(grep,awk,sed)正则表达式是不一样的,因此,代表的意义也是有较大区别的. 通配符一般用户命令行bash环境,而linux正则表达式用于grep,sed,awk ...
- Python 文件读写 文件和路径
1.在Windows上,使用倒斜杆作为文件夹之间的分隔符,在Linux上,使用正斜杠作为路径分隔符.在编写Python脚本时,可以os.path.join()函数来处理 在Windows环境下命令如下 ...
- visio画图ER图表和字段注释
最近年底属于验收的项目很多,大多数写文档中,数据库的设计ER图是比不可少的.下面记一下几个常用的用法.以下用的市visio版本为2007,由于菜单样式新版本可能有所不同,请对照相应功能进行操作! 1. ...
- 描述符应用 -- 让python变成一个强类型的语言
众所周知,python是一门弱类型的语言,变量可以随意赋值成任意类型,但是通过描述符,我们可以把数据变成强类型的. 我们为数据设置数据描述符,因为数据描述的优先级大于实例属性,所以在给数据赋值的时候会 ...
- Leetcode 96. 不同的二叉搜索树
题目链接 https://leetcode.com/problems/unique-binary-search-trees/description/ 题目描述 给定一个整数 n,求以 1 ... n ...