转C++的一点点
为什么突然放些这么水的东西?
我还是个C++小萌新,XD
【一 litTLE经验值】
1. 注意 C++里 自带pow(x,y) 使用是没问题,尤其是pow(x,0.333333)这种时候很有用。但是 自己定义的快速幂 模意义下的就要注意传参了(要么传参是全部转成我定义的,要么就把pow改成po。。。防止重名)
2. c++的 /既有整除也有小数除。 记得用上(double) 或 加上.0
3. scanf("%c",&S) 若已经到文件末尾 scanf()=-1 否则scanf()=1 可以利用函数返回值判断文件末 这个函数返回的是scanf到的变量的个数
4. 用dev调试时,首先大部分电脑 应该都是用TDM-GCC 4.8.1 32-bit Debug 或者 是64-bit的 一般没啥能用release调试的。
而且,由于c++普遍的临时变量存在,调试时要把某个重名的变量删去再添加查看。。【日。】 而且要调试的话。不能直接放在磁盘目录下,会爆炸。要建文件夹。。
dev在调试到cin cout函数的时候会卡住,所以 我都用scanf printf
F7一行执行,F8进入当前行的函数(如果有)——与pascal相反。。。 按F5运行到下一个标红的行。
5. vector.size()是unsigned, -1<vector.size()是false,记得前面加(int)。
6. C++的sort 如sort(a+l,a+r+1,cmp); 若l>r是会出事的。。。记得if判掉(等于似乎是没事的)
7. 省选惨痛的经验。记得编译选项里开-Wall
8. 在devc++的编译选项里 加入 -Wl,--stack=100000000 可以防止系统栈爆炸
9. C++的define 很强大, 但是尤其是define lc (u<<1)时 不要忘了加括号 ,因为它是文本替换。(其实不论define什么都加括号是最稳的)
10. 莫名RE怎么办,目前遇到的调试到令人发疯的 原因有:BZOJ不能用C++的time函数 ,辣鸡OJ系统栈小的可怜(递归改成手写栈)。
11. 常用函数
unique的作用是“去掉”容器中相邻元素的重复元素,而返回值是去重之后的尾地址指针
lower_bound是返回[l,r)中第一个大于等于val的位置指针,而upper_bound是大于。
int a[4]={1,1,2,2};
int n=unique(a,a+4)-a; //n=2 ,剩余序列是 [0,2)
int t=lower_bound(a,a+4,2)-a; //t=2 ,第一个≥2的是a[2]
int t=upper_bound(a,a+4,-1)-a; //t=0 ,第一个>-1的是a[0]
int t=upper_bound(a,a+4,2)-a; //t=4 , 找不到则返回末尾地址
可以加cmp cmp定义为小于号(同sort). upper_bound(a+1,a+n+1,x,cmp)-a;
nth_element(a+1,a+k,a+n+1); //将第k小的元素放到第k位,其余的,左边比第k小,右边比第k大,但不一定有序。
12.二进制中挺有用的函数:
//返回前导的0的个数。
int __builtin_clz (unsigned int x)
//返回后面的0个个数,和__builtin_clz相对。
int __builtin_ctz (unsigned int x)
builtin
13. 注意,C++中大部分函数的传参是从右到左执行的,比如自己写一个函数add,然后add(read(),read(),read()); 配上快读(read),读入的顺序是反的,比如输入顺序是1 2 3,而传参则是3 2 1。
printf("%d%d",read(),read()); 也是从右往左的。而scanf("%d%d",&x,&x)是从左往右的。
14. c++的 #include <bits/stdc++.h> 有1.6M!!
15. unsigned x; x>>k (<<也是一样的) 会自动变成 x>>(k%32);unsigned long long x; x>>k 会自动变成 x>>(k%64)。
所以手写bitset的时候 需要注意, x>>64不是0 而是 x>>0=x,要特判。
【卡常】{
- 把一系列与外界不相干的函数用struct封装起来,速度会变快。但是在struct里定义大数组,会变慢。
- 该用bool的用bool,用int会慢
- 少用operator
- 听说++x应该要比x++快? 听说 ?():()要比 if else快?
}
类型 |
比特(位)数 |
有效数字 |
数值范围 |
float |
32 |
6~7 |
-3.4*10^38~+3.4*10^38 |
double |
64 |
15~16 |
-1.7*10^-308~1.7*10^308 |
long double |
128/ |
18~19 |
-1.2*10^-4932~1.2*10^4932 |
【二 优先级】
放一个表格(转自http://www.cnblogs.com/ywl925/p/3710246.html)
记住c++里的 或 异或 & 优先级比 比较符号还低! <<和>>比+-*/低
优先级 | 操作符 | 描述 | 例子 | 结合性 |
---|---|---|---|---|
1 | () [] -> . :: ++ -- |
调节优先级的括号操作符 数组下标访问操作符 通过指向对象的指针访问成员的操作符 通过对象本身访问成员的操作符 作用域操作符 后置自增操作符 后置自减操作符 |
(a + b) / 4; array[4] = 2; ptr->age = 34; obj.age = 34; Class::age = 2; for( i = 0; i < 10; i++ ) ... for( i = 10; i > 0; i-- ) ... |
从左到右 |
2 | ! ~ ++ -- - + * & (type) sizeof |
逻辑取反操作符 按位取反(按位取补) 前置自增操作符 前置自减操作符 一元取负操作符 一元取正操作符 解引用操作符 取地址操作符 类型转换操作符 返回对象占用的字节数操作符 |
if( !done ) ... flags = ~flags; for( i = 0; i < 10; ++i ) ... for( i = 10; i > 0; --i ) ... int i = -1; int i = +1; data = *ptr; address = &obj; int i = (int) floatNum; int size = sizeof(floatNum); |
从右到左 |
3 | ->* .* |
在指针上通过指向成员的指针访问成员的操作符 在对象上通过指向成员的指针访问成员的操作符 |
ptr->*var = 24; obj.*var = 24; |
从左到右 |
4 | * / % |
乘法操作符 除法操作符 取余数操作符 |
int i = 2 * 4; float f = 10 / 3; int rem = 4 % 3; |
从左到右 |
5 | + - |
加法操作符 减法操作符 |
int i = 2 + 3; int i = 5 - 1; |
从左到右 |
6 | << >> |
按位左移操作符 按位右移操作符 |
int flags = 33 << 1; int flags = 33 >> 1; |
从左到右 |
7 | < <= > >= |
小于比较操作符 小于或等于比较操作符 大于比较操作符 大于或等于比较操作符 |
if( i < 42 ) ... if( i <= 42 ) ... if( i > 42 ) ... if( i >= 42 ) ... |
从左到右 |
8 | == != |
等于比较操作符 不等于比较操作符 |
if( i == 42 ) ... if( i != 42 ) ... |
从左到右 |
9 | & | 按位与操作符 | flags = flags & 42; | 从左到右 |
10 | ^ | 按位异或操作符 | flags = flags ^ 42; | 从左到右 |
11 | | | 按位或操作符 | flags = flags | 42; | 从左到右 |
12 | && | 逻辑与操作符 | if( conditionA && conditionB ) ... | 从左到右 |
13 | || | 逻辑或操作符 | if( conditionA || conditionB ) ... | 从左到右 |
14 | ? : | 三元条件操作符 | int i = (a > b) ? a : b; | 从右到左 |
15 | = += -= *= /= %= &= ^= |= <<= >>= |
赋值操作符 复合赋值操作符(加法) 复合赋值操作符(减法) 复合赋值操作符(乘法) 复合赋值操作符(除法) 复合赋值操作符(取余) 复合赋值操作符(按位与) 复合赋值操作符(按位异或) 复合赋值操作符(按位或) 复合赋值操作符(按位左移) 复合赋值操作符(按位右移) |
int a = b; a += 3; b -= 4; a *= 5; a /= 2; a %= 3; flags &= new_flags; flags ^= new_flags; flags |= new_flags; flags <<= 2; flags >>= 2; |
从右到左 |
16 | , | 逗号操作符 | for( i = 0, j = 0; i < 10; i++, j++ ) ... | 从左到右 |
【三 初赛二进制】
32位整数 补码: 00000000 00000000 00000000 00000101 这是5
00000000 00000000 00000000 00000000 这是0
11111111 11111111 11111111 11111111 这是-1
11111111 11111111 11111111 11111110 这是-2
11111111 11111111 11111111 11111101 这是-3
11111111 11111111 11111111 11111100 这是-4
11111111 11111111 11111111 11111011 这是-5
11111111 11111111 11111111 11111010 这是5取反的结果-6 所以计算机对整数的运算用的是补码(别再忘了QAQ
即正数原反补不变 ; 负数对我们所熟知的原码 除符号位外 取反+1: -1的原码 10000001
-1的补码 11111111
-1的反码 11111110 所以举例:树状数组中 6&-6 就是 -6取反=11…11001 再+1 11…11010 则00…0110&11…1010 就是6的最小非0位(lowbit) 【2020.2.23更新】
https://www.cnblogs.com/zsq1993/p/5792065.html
关于 *和const 优先级等的细节
{
const int a; 等价于 int const a;
short int a; 等价于 int short a;
} {
int x,y;
//[]优先于* int *a[]; //可理解为 int* a[10]
a[]=&x; int (*b)[]; //b指针 用来指向 int[10],但是初始b没有被定义指向
int c[][];
b=&(c[]);
(*b)[]=;
printf("%d\n",c[][]);
} {
int x,y,z,w;
const int *a;
int const *b; //a和b是一样的
int *const c=&z; //指针常量 必须得赋初值 a=&x;
x=; //可以
//*a=1; 不可以 b=&y;
y=; //可以
//*b=2; 不可以 z=; //c指针是只读,但指向位置的值没关系
*c=; //可以 int const *const d=&w; //将前两者结合
w=;
}
转C++的一点点的更多相关文章
- 利用animation和text-shadow纯CSS实现loading点点点的效果
经常在网上看到loading状态时的点点点的动态效果,自己也用JS写了一个,思路是使用一个计数参数,然后在需要添加点的元素后面利用setInterval一个一个加点,当计数到3时,把点变为一个--写完 ...
- Android--带你一点点封装项目 MVP+BaseActivity+Retrofit+Dagger+RxJava(一)
1,其实早就想把这些东西给封装封装的,一直没有时间,今天刚好项目进入到测试阶段了,Bug同事在哪儿测试的飞起,但发现提bug的尽然是我(得意脸),然后上午把ios的包测试了一下,顺便把服务器给测挂了( ...
- 在input中实现点点点与当鼠标移上去时显示剩余的字
项目中经常会遇到这个问题,在一个内容框中,由于框的宽度是固定的,但是里面的内容却有很多,那么这个时候需求里就要求第一,多余的字要以点点点的形式隐藏,第二,当鼠标移上去的时候要以title提示的方式显示 ...
- css 文本显示点点点
今天有这个需求,百度获取到这个效果,记录下来. text-overflow :ellipsis; //让截断的文字显示为点点.还有一个值是clip意思是截断不显示点点 white-space : no ...
- 怎么实现CSS限制字数,超出部份显示点点点.
如何实现CSS限制字数,超出部份显示点点点... <div style="width:200px; white-space:nowrap;overflow:hidden;text-ov ...
- jQuery关于文字内容溢出用点点点(…)省略号表示
1.jQuery限制字符字数的方法代码很简单,使用也很方便,如下: $(document).ready(function(){//限制字符个数$(“.zxx_text_overflow”).each( ...
- 【Open Search产品评测】-- 淘点点:基于OpenSearch,轻松实现一整套O2O类搜索解决方案
[Open Search产品评测]-- 淘点点:基于OpenSearch,轻松实现一整套O2O类搜索解决方案 [使用背景] 我们淘点点团队应该可以算是内网首批使用opensearch来搭建应用 ...
- 重拾C,一天一点点_4_随想
刚才顺便又把二分默写了一遍,还好,这次比较顺利.算法这一块,一直是自己一块痛处,有时感觉自己的脑瓜子怎么就这么笨,后一想觉得肯定是锈逗了,确实啊,这么长时间不思考的脑子能机灵到哪呢?早就意识到这个问题 ...
- 重拾C,一天一点点_2
类型转换一般来说,如果二元运算符的两个操作数具有不同的类型,较低的类型提升为较高类型,结果为较高类型.表达式由float类型的操作数不会自动转换为double类型.使用float类型主要是为了在使用较 ...
- 重拾C,一天一点点
数据类型及长度 char 字符型,占用一个字节 int 整型,通常代表特定机器中整数的自然长度 short 16位 int 16位或32位 ...
随机推荐
- 利用Thinkphp 5缓存漏洞实现前台Getshell
0×00 背景 网站为了实现加速访问,会将用户访问过的页面存入缓存来减小数据库查询的开销.而Thinkphp5框架的缓存漏洞使得在缓存中注入代码成为可能.(漏洞详情见参考资料) 本文将会详细讲解: 1 ...
- POJ 1017 Packets(积累)
[题意简述]:这个是别人的博客,有清晰的题意描写叙述.和解题思路,借助他的想法,能够非常好的解决问题! [分析]:贪心?模拟?见代码 //216K 16Ms #include<iostream& ...
- 初涉IPC,了解AIDL的工作原理及用法
初涉IPC,了解AIDL的工作原理及用法 今天来讲讲AIDL.这个神奇的AIDL,也是近期在学习的,看了某课大神的解说写下的blog,希望结合自己的看法给各位同价通俗易懂的解说 官方文档:http:/ ...
- myeclipse2014破解
去年出现的struts2 bug问题,在过去的项目中一直没做调整,前段时间发现受到影响了.本想这个bug都已经这么长时间了,工具中的包应该也已经被替换了吧,于是下载了最新的myeclipse2014, ...
- vue-class-component 以class的模式写vue组件
vue英文官网推荐了一个叫vue-class-component的包,可以以class的模式写vue组件.vue-class-component(以下简称Component)带来了很多便利: 1.me ...
- LINUX下目标文件的BSS段、数据段、代码段
http://blog.chinaunix.net/uid-27018250-id-3867588.html bss 未初始化的全局数据 data 已经初始化的全局数据 text 代码段,机器指令 r ...
- ios文件系统文件目录操作
对于一个运行在iPhone得app,它只能访问自己根目录下得一些文件(所谓sandbox). 一个app发布到iPhone上后,目录结构如下: 1.其中获取 app root 可以用 NSHomeDi ...
- 【转载】C#中的==、Equal、ReferenceEqual
1. ReferenceEquals, == , Equals Equals , == , ReferenceEquals都可以用于判断两个对象的个体是不是相等. a) ReferenceEquals ...
- 英特尔和Red Hat合作实现Gnome桌面的Wayland支持
在发布支持XMir的Linux图形驱动程序xf86-video-intel 2.99.901后数天,英特尔宣布撤回对XMir的支持,XMir补丁不会合并到上游项目.XMir是Mir显示服务器的X11兼 ...
- KVM技术
今天是周六,看到一片KVM相关的文章,感觉写得很不错,翻译了,原文在这里:KVM Technology 在开放服务器虚拟化的应用方面,KVM虚拟化技术近年来广受关注.自从2006年10月份诞生以来,其 ...