《算法笔记》(胡凡)day1-C语言与C++入门

引言

《算法笔记》是针对研究生复试上级,考取PAT等级,CCF的CSP认证编写的算法学习指导书籍,配合《算法笔记上级训练实战指南》效果更好。

写者作为一个CS专业的大学生马上面临着考研or保研的考验,因此对于能够抵机试成绩的算法等级考试具有浓厚兴趣,特此写文,记录自己学习算法的过程。

C/C++快速入门

一.简介

该部分是为了帮助读者快速上手编写程序所写,具有C/C++基础的读者,可以直接跳过了。
但是如果读者跟写者一样,学过C/C++的基础语法,但是对具体的细节不能熟练掌握可以按照需要选择合适的部分。

这里我们不再深究C/C++基础语法,只对算法中的常用部分进行说明。

另:这里我们以C语言为主,一方面是C++向下兼容C,可以用C处理C++的大部分问题,另一方面,相比C++,C的处理速度更快,能够一定程度上减少超时现象的出现。

二.数据类型的取值范围

这是很多人在写算法的时候容易忽视的一部分,因为在很多考试中,对于测试数据的范围往往有明确要求,了解这些变量的取值范围能够有效避免超出范围的情况。

1.整型

分为short,int,long long,其中short用到的比较少,不再赘述
对于int类,一个整数占据32bit,即4Byte,取值范围自然为
在这里插入图片描述
而对于long long类的长整型,一个整数占据64bit,也就是8Byte,取值范围为
在这里插入图片描述

2.浮点型

对单浮点型float来说,取值范围为在这里插入图片描述
但是有效精度只有6~7位,对于精度要求高的问题不适用。

对于双精度double来说,取值范围为
在这里插入图片描述
有效位数为15~16位,比起float优秀得多。

二.常用的match函数

1.fabs(double x) 求绝对值

2.floor(double x)和ceil(double x)分别为向下和向上取整数

3.pow(double r, double p)求r的p次幂

4.sqrt(double x)算数平方根

5.log(double x)返回double型变量的以自然数为底的对数

6.sin(double x),cos(double x)和tan(double x)弧度制求三角函数

7.在第六条函数前加“a”会求反三角函数

8.round(double x)求x的四舍五入

三.数组

基础语法不再赘述,下面介绍数组中常用的函数

1.memset-对数组中每个元素赋一个相同的值

格式为:
memset(数组名,值,sizeof(数组名))

需要注意的是memset需要程序开头添加string.h头文件,只建议初学者只给数组赋值0或者-1。这是因为memset使用的是按字节赋值,即对每个字节赋相同的值,组成int型的4个字节会被赋成相同的值。如果要赋值为其他数字请使用fill函数,我们日后会说到。

2.字符数组

要注意字符数组会在末尾自动添加空字符“\0”,在使用gets和scanf输入时会自动添加到后面,并占据一个字符位置,而puts和printf就是通过识别\0来停止的。
特别提示1:结束符会占据一个字符长度,因此字符数组长度要比实际存储的字符串长度多1
特别提示2:如果不是使用scanf或gets输入字符串,例如使用getchar一定要在输入的每个字符串后手动添加\0,否则会有乱码。

3.string.h头文件

1.strlen()可以得到字符数组中第一个\0前的字符的个数
2.strcmp(字符数组1,字符数组2)返回两个字符串大小的比较结果,比较原则是按照字段顺序,如果1<2,返回一个负数;1==2,返回0;1>2,返回正整数。
3.strcpy(字符数组1,字符数组2)把2的内容复制给1,包括了结束符。
4.strcat(字符数组1,字符数组2)把2字符串接到1后面

四.指针与引用

1.引用与指针的区别

引用是C++中的语法。

众所周知,函数的参数是作为局部变量使用的,对局部变量的操作不会影响外部的变量,如果要修改传入的参数,就只能使用指针。但是引用可以不使用指针。引用实际不产生副本,而是给原变量起了一个别名。使用引用的方法很简单,只需要在函数的参数类型后面加一个&即可。
在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 《算法笔记》是由胡凡编写的一本关于算法学习的教材,它最初以C/C++为主要编程语言。这本教材主要面向想要学习算法的初学者,以及希望进一步提升算法能力的人群。 《算法笔记》的内容广泛而且深入,涵盖了很多算法的基础知识和主要思想,如递归、排序、查找、图论、动态规划等。通过学习这本教材,读者可以掌握这些算法的基本原理和实现方法,提高解决实际问题的能力。 该教材有几个特点:首先,它提供了很多例子和习题,帮助读者巩固所学的知识;其次,它介绍了很多常用的数据结构,如数组、链表、栈、队列等,读者可以通过学习这些数据结构更好地理解和应用算法;最后,它还介绍了一些高级主题,如高级数据结构、算法优化等,这些内容对于进一步提升算法水平非常有帮助。 《算法笔记》是一本入门级的教材,因此在阅读时需要一些基本的编程知识和逻辑思维能力。该教材的语言简洁明快,适合作为学习参考书,同时也可以作为算法竞赛的辅助教材。 总而言之,《算法笔记》是一本很好的算法学习教材,它以C/C++为编程语言,全面介绍了算法的基本知识和常用方法,适合想要学习算法的初学者。无论是学术研究还是实际应用,阅读《算法笔记》都能提升算法能力,并为进一步学习和应用算法打下坚实的基础。 ### 回答2: 《算法笔记 胡凡 c/c 快速入门pdf》是一本介绍算法和C/C++编程语言的入门书籍。该书的作者是胡凡,它主要规划了算法的学习路径以及基本的C/C++编程语言。这本书适合初学者快速入门,对于想要系统学习算法和C/C++编程的人来说是一本不错的选择。 这本书的内容非常系统和全面。它以算法和数据结构为基础,包括基本排序、查找、图论等算法的介绍和实践,让读者能够快速掌握这些算法的原理和实现方法。同时,它还介绍了C/C++语言的基础知识和编程技巧,帮助读者理解和运用这些知识。 书中每章都有一些练习题,帮助读者巩固所学的知识。同时,每个章节末尾还提供了一些进阶的题目和参考答案,供读者深入学习和自我检测。这样的设计能够帮助读者更好地理解和掌握所学的内容。 总的来说,《算法笔记 胡凡 c/c 快速入门pdf》是一本很好的算法和C/C++入门书籍。它能够帮助读者快速了解算法和数据结构的基础知识,并学会使用C/C++语言进行编程。无论是对于想要入门算法和C/C++编程的初学者,还是已经有一定基础的读者,这本书都是一个很好的选择。 ### 回答3: 《算法笔记胡凡C/C++快速入门PDF》是一本很棒的入门算法书籍。这本书主要介绍了常用的数据结构与算法,并通过C/C++语言来实现这些算法。 首先,这本书非常适合算法初学者。它从基础的数据结构开始讲解,如数组、链表、栈和队列,然后逐渐引入更复杂的数据结构,如二叉树、图和堆。此外,书中还介绍了常用的排序和查找算法,如冒泡排序、快速排序、二分查找等。每个算法都配有具体的代码实现和详细的解释,帮助读者理解算法的原理和应用。 其次,这本书的学习资料丰富。书中提供了很多例题和习题,读者可以通过实践来巩固所学的知识。此外,书中还介绍了一些常见的算法优化技巧和设计思路,提供了一些高效解决问题的方法和思考方式。 最后,这本书的编写风格简明易懂。作者通过清晰的语言和简洁的代码,将复杂的算法问题简化为易于理解的部分。不论是对于算法初学者还是对于有一定编程基础的读者,这本书都是一本很好的学习资料。 总而言之,《算法笔记胡凡C/C++快速入门PDF》是一本很好的入门算法书籍。它适合初学者学习和理解常用的数据结构与算法,通过具体的代码实现和详细的解释帮助读者掌握算法的原理和应用。无论是编程初学者还是有一定基础的读者,都可以从这本书中获得丰富的知识和实践经验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值