C/C++入门

时间:2021-08-05
本文章向大家介绍C/C++入门,主要包括C/C++入门使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

C:面向过程-函数

C++:面向对象-类;向下兼容C

程序包含头文件+主函数

简单数据类型

long long型赋超过int型范围的初值,需要在初值后面加上LL,否则可能会编译错误

不要使用float,碰到浮点型的数据直接使用double

常量可以赋值给变量

小写字母比大写字母的ASCII码值大32

(新类型名)变量名 //强制类型转换
#define 标识符 常量  //符号常量-宏定义
const 数据类型 变量名 = 常量;  //const常量

两个整形做除法运算会向下取整

宏定义实现两数取较大值:#define MAX(a,b) ((a)>(b)?(a):(b))

常用左移运算符来表示无穷大数INF:const int INF =(1<<30)-1; //0x3fffffff

C语句

%c把空白符按字符读入;其他格式符的输入以空白符(空格、Tab、换行)为结束判断标志

double型的输入输出格式符不同

要输出'%''\',需要在前面再加一个符号:printf("%%");

实用的输出格式:

printf("%5d\n",a);  //右对齐输出,高位用空格补齐
printf("%05d\n",a);  //右对齐输出,高位用0补齐
Printf("%.3f\n",a);  //保留m位小数输出

输入输出字符:getchar();putchar();

常用math函数:

fabs(double x);  //取绝对值
floor(double x);ceil(double x);  //向上取整和向下取整
pow(double r,double p);  //r的p次方
sqrt(double x);  //算术平方根
log(double x);  //以自然对数为底的对数,其他为底的对数要用换底公式
sin(double x);cos(double x);tan(double x);  //弧度制
asin(double x);acos(double x);atan(double x);  //返回变量的反正弦值、反余弦值、反正切值
round(double x);  //四舍五入

pi可以定义为精确值:const double pi = acos(-1.0);

if语句、while条件判断如果表达式是“!=0”,则可以忽略“!=0”;如果表达式是“==0”,则忽略并在表达式前添加“!”

数组

数组大小较大时(10的6次方级别),需要将其定义在主函数外面

memset(数组名,值,sizeof(数组名)); //对数组每个元素赋值,按字节赋值,建议只赋0或-1

gets识别换行符作为输入结束,因此scanf完其他类型后,如果要使用gets,需要先用getchar接收空白符

如果不是使用scanf的%s格式或gets函数输入字符串,一定要再输入字符串的最后加入’\0‘,不然输出字符串会出现乱码

strlen(字符数组); 得到字符数组第一个\0前字符的个数
strcmp(字符数组1,字符数组2); 比较两个字符串大小,字典序
strcpy(字符数组1,字符数组2); 把2复制给1
strcat(字符数组1,字符数组2); 把2拼接到1后面

函数

函数传递参数的方式是值传递,函数定义内的参数为形参,实际调用的参数为实参

数组作为参数时,函数定义第一维不需要写长度,实际调用只需要写数组名

在函数中对数组元素的修改就等于对原数组元素的修改

数组不允许作为返回类型出现

函数的嵌套调用:在一个函数中调用另一个函数

函数的递归调用:一个函数调用该函数自身

指针

一个指针指向一个变量

指针是一个unsigned类型的整数

int* a; //*放在数据类型后和变量名前都可以,放在数据类型后且有多个变量时,*只作用于第一个变量名

指针变量定义时*是变量类型说明的一部分,指针变量使用时*是取出指针指向数据的钥匙

两个int型的指针相减,等价于在求两个指针之间相差了几个int;其他类型的指针同样适用

函数参数为指针变量时,传递方式为地址传递

定义指针变量时如果没有初始化,它存放的地址是随机的,如果该随机地址指向的是系统工作区间,那么接下来变量改变时容易出错;所以要初始化

引用:给原变量起了一个别名,对引用变量的操作就是对原变量的操作;在函数定义时把&加在变量名前面

结构体

结构体内不能定义本身类型,可以定义自身类型的指针变量

struct stu{
	int id;
	char name[20];
	stu* next;
}stu,*p;
//访问元素
stu.id
stu.name
(*p).id
(*p).name
p->id
p->name
//两种写法完全等价
    
//构造函数
struct stu{
    int id;
    char gender;
    stu(){}
    stu(int _id,char _gender){
        id=_id;
        gender=_gender;
    }
};
//实例
stuInfo = stu(100,'M');

技巧

const double eps=1e-8;
const double Pi=acos(-1.0);

#define Equ(a,b) ((fabs((a)-(b)))<(eps))
#define More(a,b) (((a)-(b))>(eps))
#define Less(a,b) (((a)-(b))<(-eps))
#define MoreEqu(a,b) (((a)-(b))>(-eps))
#define LessEqu(a,b) (((a)-(b))<(eps))

黑盒测试:系统后台会准备若干组输入数据,然后让提交的程序去运行这些数据,如果输出的结果与正确答案完全相同(字符串意义上的比较),那么就称通过了这道题的黑盒测试,否则会根据错误类型而返回不同的结果。

单点测试:按正常逻辑执行一遍程序

多点测试

​ 1.默认读取到文件末尾

while(scanf("%d",&n)!=EOF){}
while(gets(str)!=null){}

​ 2.输入数据满足条件时停止输入

在while...EOF内部进行判断;直接把推出条件的判断放到while语句中

​ 3.while(t--)

原文地址:https://www.cnblogs.com/-TheMilkyWay/p/15102124.html