C/C++基础-书和笔记

零、常识

0.1 时空复杂度边界

  • 时间:一般时间复杂度超过109,一定就超时了

  • 空间:int 类型 106就超过内存了

0.2 不动态申请内存

  • 尽量不用指针和动态申请内存。
  • 链表用c语言实现,申请内存空间用,#include<malloc.h>

0.3 ascll 码

空格 32
0-9 : 48-57
A-Z : 65-90
a-z : 97-122

0.4 指针

在声明变量中int* a表示a是一个指向int类的指针
在使用变量时*a表示的是a这个指针指向的地址存放的变量的值

0.5 头文件

#include<iostream>  //C++标准输入输出,cin/cout
#include<cstdlib>
#include<cstdio>    //c标准输入输出,scanf/printf
#include<algorithm> //常用算法,比如快速排序sort函数
#include<map><vector><string><set> //STL相应模块
#include<cstring>    //c语言字符串相关,memset函数所在头文件

一、进位制与整数表示

1.1进制输出

printf("%d%o%x\n",a);
把整数a按照十进制、八进制和十六进制输出

如果是C++
默认状态下,数据按十进制输入输出。如果要求按八进制或十六进制输入输出,在cin或cout中必须指明相应的数据形式,oct为八进制,hex为十六进制,dec为十进制。

 1 int i, j, k, l;
 2 cout<<”Input i(oct), j(hex), k(hex), l(dec):<<endl;
 3 cin>>oct>>i; //输入为八进制数
 4 cin>>hex>>j; //输入为十六进制数
 5 cin>>k; //输入仍为十六进制数
 6 cin>>dec>>l; //输入为十进制数
 7 cout<<”hex:<<”i=<<hex<<i<<endl;
 8 cout<<”dec:<<”j=<<dec<<j<<′\t′<<”k=<<k<<endl;
 9 cout<<”oct:<<”l=<<oct<<l;
10 cout<<dec<<endl; //恢复十进制输出状态
11 
12 【执行结果】:
131)输出提示:Input i(oct), j(hex), k(hex), l(dec):
142)此时从键盘输入: 032 0x3f 0xa0 17 <CR>
153)输出结果为:
16 
17 hex:i=1a
18 dec:j=63 k=160
19 oct:l=21

必须在cin中指明数制,否则从键盘输入时,不认八进制和十六进制数开头的0和0x标志。指明后可省略0和0x标志。
进制控制只适用于整型变量,不适用于实型和字符型变量。

输入数据的格式、个数和类型必须与cin中的变量一一对应,否则不仅使输入数据错误,而且影响后面其他数据的正确输入。

在cin或cout中指明数制后,该数制将一直有效,直到重新指明使用其他数制。

1.2进制转换与位移

  1. 二进制转十进制
    左移一位 = 乘以2 =<<1
    eg1: (10101)2 = ((1*2+0)*2+1)*2+0)*2+1
    eg2: 28-1 = (1<<8)-1
    注意
    移位运算符的优先级低于加减运算

1.3 int溢出

在这里插入图片描述
在一些题目中注意溢出的问题

二、C++字符串

做函数参数

在传递参数的时候,如果参数是string类型,可以用string类型的引用,减少内存的拷贝。

void funs(const string& str1)
{
	string str;
	str=str1;
	...
}

这里形参用的就是引用,所以str1的地址就是实参的地址
但因为声明const,实参不能改变,所以函数内部用str做处理

基础操作

  • front和back
chr1=s.front()//取第一个字符
chr2=s.back()//去最后一个字符
s.front()='a'//给第一个字符赋值
s.back()='b'//给第二个元素赋值

vector也可以用front和back取第一个最后一个元素

  • 赋值:用“=”号

  • 连接:用“+”号

  • 长度:s.size()

  • 插入子串:s.insert(插入位置,”子串”);

  • 删除子串:s.erase(开始位置,长度);

  • 替换子串:s.replace(开始位置,替换长度,替换成什么)

  • 查找子串:s.find(要找的内容,查找起始位),
    查找不到返回string::npos,找到返回起始位置

//找到subs在s中的位置,把subs从s中取出
#include<string>
string s,s0;
if(s.find(subs,0)!=string::npos)
{
	n1=s.find(subs,0);
}
string r=s.substr(n1,subs.length());

  • 取子串易搞错
    取子串:s.substr(开始位置,长度);
    这里写图片描述如果从第0个位置开始,取到第二个位置(取到’c’)
s.substr(0,3);//而不是substr(0,2)

三、数组

3.1 声明

不确定大小的时候,数组一般会开的大一些

  • 注意比较大的数组声明放在main函数外,否则程序可能无法运行
	define maxn 100000
	int a[maxn];
	int main()
	{
		...
	}

3.2 结构体(数组)和排序

3.2.1 定义结构体和结构体数组
struct 结构体名称{
    变量类型 变量名;
};

struct 结构体名称 结构体变量名;
struct 结构体名称 结构体数组名[数组长度];
typedef struct Student{
	int age;
	int score;
	int sno;
}Stu;

Stu stu1;
Stu stu2[30];
3.2.2 cmp重定义

如果对结构体排序,使用algorithm,需要对cmp函数重定义

bool cmp(Stu a,Stu b)
{
//先按年龄,从小到大
   if(a.age<b.age) return true;
//年龄相等按成绩排,从小到大
   else if(a.age==b.age && a.score<b.score) return true;
   else return a.sno<b.sno;
}
3.2.3 例题

这里写图片描述
排序

#include<algorithm>
bool cmp(int a,int b)
{return a>b;}//从大到小排序
int a[N];
sort(a,a+N,cmp);//对数组a中的元素按照cmp定义的排序规则排序

定义结构体数组,初始化
先声明结构体,再去定义结构体数组

struct 结构体名{
成员列表;
};
struct 结构体名 数组名[长度] = {{成员值列表},…{成员值列表}};

字符串比较
strcmp(char *s1,char *s2)
返回值
大于0 ---------------- 第一个字符串大于第二个字符串
小于0 ---------------- 第一个字符串小于第二个字符串
等于0 ---------------- 两个字符串相等

#include<stdlib.h>
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
typedef struct student
{
	char name[100];
	int age;
	int grade;
}Stu;

bool cmp(Stu a,Stu b)
{
	if(a.grade!=b.grade) return a.grade<b.grade;
	if(strcmp(a.name,b.name)) return a.name<b.name;
	return a.age<b.grade;
}

int main()
{
	int n;
	while(scanf("%d",&n)!=EOF)
	{
		Stu stu[n];
		for(int i=0;i<n;i++)
		{
            scanf("%s",stu[i].name);
			scanf("%d",stu[i].age);
			scanf("%d",stu[i].grade);
		}
		sort(stu,stu+n,cmp);
		for(int j=0;j<n;j++)
		{
			printf("%s ",stu[j].name);
			printf("%d ",stu[j].age);
			printf("%d\n",stu[j].grade);
		}
	}
	return 0;
}

3.3 memset初始化

memset(数组名,0/-1,sizeof(数组名))可以直接将数组初始化为全0/全1/全-1
注意 memset只能初始化为0/-1,初始化为其他值行不通

3.4 字符数组

【读入】
scnaf("%s",s)会读入一个不含空格、回车和TAB的字符串,存入字符数组s。
注意 不要在s前面加&

【基本操作】

#include<string.h>
char a[10],b[10];
  • strlen(s):返回s中结束标记’/0’之前的字符个数

  • strcpy(a,b):赋值

  • strcmp(a,b):比较
    返回值
    大于0 ---------------- 第一个字符串大于第二个字符串
    小于0 ---------------- 第一个字符串小于第二个字符串
    等于0 ---------------- 两个字符串相等

  • strcat(a,b):连接

3.4 数组做参数和返回值

数组做参数的时候

int sum(int a[])
等价于
int sum(int* a)

传递的只是数组的首地址

四、递归

4.1 递归

使用递归最重要的是定义递归终止条件

段溢出的原因有两种:

  • 调用太多
  • 局部变量过大
    因为调用关系和局部变量都存放在堆栈段中
递归思想

把问题分解成规模小的两个子问题
集合的思想A=A1+A2,A1和A2是A的子集,并且是互斥的子集

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值