系列文章目录
#include<bits/stdc++.h>
文章目录
1、预处理
概述
在编译之前对源文件进行简单加工的过程,就称为预处理。
作用
预处理器的主要作用就是: 把通过预处理的内建功能对一个资源进行等价替换,最常见的预处理有: 文件包含,条件编译、布局控制和宏替换4种。
文件包含: #include 是一种最为常见的预处理,主要是做为文件的引用组合源程序正文。
条件编译: #if,#ifndef,#ifdef,#endif,#undef等也是比较常见的预处理,主要是进行编译时进行有选择的挑选,注释掉一些指定的代码,以达到版本控制、防止对文件重复包含的功能。
布局控制: #progma,这也是我们应用预处理的一个重要方面,主要功能是为编译程序提供非常规的控制流信息。
宏替换: #define,这是最常见的用法,它可以定义符号常量、函数功能、重新命名、字符串的拼接等各种功能。
地址
为什么要预处理?
Windows 平台下的暂停函数的原型是void Sleep(DWORD dwMilliseconds)(注意 S 是大写的),参数的单位是“毫秒”,位于 <windows.h> 头文件。
Linux 平台下暂停函数的原型是unsigned int sleep (unsigned int seconds),参数的单位是“秒”,位于 <unistd.h> 头文件。
不同的平台下必须调用不同的函数,并引入不同的头文件,否则就会导致编译错误,因为 Windows 平台下没有 sleep() 函数,也没有 <unistd.h> 头文件,反之亦然。这就要求我们在编译之前,也就是预处理阶段来解决这个问题。
总结
在不同的平台下,编译之前(预处理之后)的源代码都是不一样的。这就是预处理阶段的工作,它把代码当成普通文本,根据设定的条件进行一些简单的文本替换,将替换以后的结果再交给编译器处理。
2、函数重载
条件
函数名相同,形参数量不同,形参类型不一样,形参顺序不一样
3、std::
std::是个名称空间标识符,C++标准库中的函数或者对象都是在命名空间std中定义的,所以我们要使用标准库中的函数或者对象都要用std来限定。
一般来说,std都是要调用C++标准库时使用。比如:使用标准库文件iostream时,要写上std;使用非标准库文件iostream.h,不用写。
1.将命名空间释放出来
using namespace std 告诉编辑器我们将要使用名字空间std中的函数或者对象,所以cout和endl前面不用注明他们是std这个名字空间中的cout和endl。
1.分别将cout和endl释放出来
using std::cout;
using std::endl;
地址
4、基姆拉尔森日期公式
计算给定日期星期几
W= (d+2m+3(m+1)/5+y+y/4-y/100+y/400) mod 7
地址1
地址2
5、ceil函数
通过头文件#include<bits/stdc++.h>使用,可以向上取整
6、浮点计算
#include<iomanip>
cout<<fixed<<setprecision(n)
7、三目运算
C++要全括号?
cout<<(n%2==0?"even":"odd");
cout<<(n>50&&n%2==0?"yes":"no");
8、字符串输入判断
while(s=getchar(),s!='?')
通过while和getchar配合,加上判断条件
9、素数判断
链接:https://ac.nowcoder.com/acm/problem/22200
来源:牛客网
第一行输入一个整数T,表示需要判断的数的个数
接下来T行每行一个整数n,表示需要判断的数。
1<=n<=1e5,1<=T<=10
#include <bits/stdc++.h>
using namespace std;
int m,n;
bool prime(int n)
{
if(n<2) return false;
for(int i=2;i<=sqrt(n);i++)
if(n%i==0) return false;
return true;
}
int main()
{
cin>>m;
while(m--)
{
cin>>n;
if(prime(n)) cout<<"Yes"<<endl;
else cout<<"No"<<endl;
}
return 0;
}
9、C++中如何使输出对齐
10、约瑟夫问题
可简化为递归问题,当人数n=1时,这个人是唯一解f;当n=2时,解为(f+(第几人出局)m)%n;以此类推,递归方式列出代码。
#include<iostream>
using namespace std;
int main()
{
int n,k,m,f=0;
cin>>n>>k>>m;
for(int i=1;i<=n;i++)
f=(f+m)%i;
cout<<(k+f)%n;
}