CS50笔记(查漏补缺)
准备一个暑假在跑外卖的时候干点有用的事,就从学习CS50开始吧,正好学点自己不知道到的知识。
2024-07-17~2024-08-17 结束正好用时一个月,也终于结束了,因为不是零基础,所以有些课程跳了,有的太简单了,还是挺有感慨的,以前发现自己编程同龄人无敌,现在才发现任重道远,开学后要好好学学指针。
并归排序
还是基础功不太扎实,连这个都不知道。
归并排序基于分治思想将数组分段排序后合并,主要思想是将两个已经排好序的数合并在一起。
注意:这个算法必须申请至少两倍空间,首先,设定两个指针,这两个指针在两个已经排好的数组的起始位置。
合并:从左向右,枚举两个数组
a[i]
和b[i]
,找出最小的数放入新数组,直到有一个数组为空时,把另一个数组的剩下的元素放入新数组。分治:如果数组长度为 1,该数组就是有序的,不用排序。如果数组长度大于 1,此时应将该数组分为两段,等分成左边和右边,检查有无序,无序重复此操作,左边有序后检查右边,两变边都有序了,合并(见2操作)。
给一张动图吧,好理解一些,网上的:
C 标准库 <string.h>
strcmp()
int strcmp(const char *str1, const char *str2)
str1 ------ 要进行比较的第一个字符串
str2 ------ 要进行比较的第二个字符串
返回值如下: * 如果返回值小于 0,则表示 str1 小于 str2。 * 如果返回值大于 0,则表示 str1 大于 str2。 * 如果返回值等于 0,则表示 str1 等于 str2。
strcpy()
char *strcpy(char *dest, const char *src)
dest -- 指向用于存储复制内容的目标数组。
src -- 要复制的字符串。
C 标准库 <stdlib.h>
malloc()
C 库函数 void *malloc(size_t size)
分配所需的内存空间,并返回一个指向它的指针。
void *malloc(size_t size)
size -- 内存块的大小,以字节为单位。
free()
C 库函数 void free(void *ptr)
释放之前调用
calloc、malloc 或 realloc 所分配的内存空间。
void free(void *ptr)
ptr -- 指针指向一个要释放内存的内存块,该内存块之前是通过调用 malloc、calloc 或 realloc 进行分配内存的。如果传递的参数是一个空指针,则不会执行任何动作。
C 标准库 <stdio.h>
文件操作
fopen()
可以使用 fopen() 函数来创建一个新的文件或者打开一个已有的文件,这个调用会初始化类型 FILE 的一个对象,类型 FILE 包含了所有用来控制流的必要的信息。下面是这个函数调用的原型:
FILE *fopen( const char *filename, const char *mode );
filename ----- 字符串,用来命名文件。
mode --------- 访问模式,有下面几种格式:
模式 | 描述 |
---|---|
r | 打开一个已有的文本文件,允许读取文件。 |
w | 打开一个文本文件,允许写入文件。如果文件不存在,则会创建一个新文件。在这里,您的程序会从文件的开头写入内容。如果文件存在,则该会被截断为零长度,重新写入。 |
a | 打开一个文本文件,以追加模式写入文件。如果文件不存在,则会创建一个新文件。在这里,您的程序会在已有的文件内容中追加内容。 |
r+ | 打开一个文本文件,允许读写文件。 |
w+ | 打开一个文本文件,允许读写文件。如果文件已存在,则文件会被截断为零长度,如果文件不存在,则会创建一个新文件。 |
a+ | 打开一个文本文件,允许读写文件。如果文件不存在,则会创建一个新文件。读取会从文件的开头开始,写入则只能是追加模式。 |
fclose()
为了关闭文件,请使用 fclose() 函数。函数的原型如下:
int fclose( FILE *fp );
如果成功关闭文件,fclose() 函数返回零,如果关闭文件时发生错误,函数返回 EOF。
fprintf()
函数 fprintf() 函数根据指定的格式发送信息到由stream(流)指定的文件。因此 fprintf() 可以使得信息输出到指定的文件。
int fprintf( FILE *stream, const char *format, ... );
第一个参数是文件指针,第二个和后面都和printf() 一样的。将内容输出到字符串中。
fread()
C 库函数 size_t fread(void ptr, size_t size, size_t nmemb, FILE stream) 从给定流 stream 读取数据到 ptr 所指向的数组中。
size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream)
参数:
- ptr -- 这是指向带有最小尺寸 size*nmemb 字节的内存块的指针。
- size -- 这是要读取的每个元素的大小,以字节为单位。
- nmemb -- 这是元素的个数,每个元素的大小为 size 字节。
- stream -- 这是指向 FILE 对象的指针,该 FILE 对象指定了一个输入流。
SQL
SELECT
1 |
|
column1, column2, ...:要选择的字段名称,可以为多个字段。如果不指定字段名称,则会选择所有字段。
table_name:要查询的表名称。
注意:在
SELECT
后在加DISTINCT
可以去重
WHERE
1 |
|
WHERE 相当于 if ,condition
是条件。
ORDER BY
1 |
|
- column1, column2, ...:要排序的字段名称,可以为多个字段。
- ASC:表示按升序排序。
- DESC:表示按降序排序。
本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!