实现数据结构与算法需要掌握的C语言
我使用C语言并不频繁,一般都是用来实现数据结构与算法,因为面向过程的编程方式容易理解算法的原理,但是呢,如果很长时间没写算法,那么就意味着C语言的某些语法就生疏了,但是总有那么一些,在写算法的时候,特别常用的,所以,我就专门写下来,不用再没头没脑的复习C语言了。
在提醒一下,这里只说C语言,不涉及C++。
声明普通变量
#include<stdio.h>
int main()
{
int iVar = 10;
float fVar = 10.01;
double dVar = 10.001;
//bool flag = true;//C语言中没有bool类型
char cVar = 'a'; //字符类型使用单引号括起来 printf("%d\n", iVar);
printf("%f %f\n", fVar, dVar);
printf("%c\n", cVar);
printf("%s\n", NAME);
return 0;
}
声明指针
int *ptr = NULL; //这里请使用大写的NULL,小写的null不对
int a = 10;
ptr = &a;
printf("%p %d\n", ptr, *ptr);
声明数组
//定义整型数组(浮点型是一样的)
int arrInt[10] = {1,2,3,4,5,6,7,8,9,10}; //也可不指定数组长度,长度会根据实际的元素个数来设置
int arrInt2[] = {9,8,7,6,5,4,3,2,1};
printf("%d\n", sizeof(arrInt) / 4); //10
printf("%d\n", sizeof(arrInt2) / 4); //9 int i = 0; //遍历数组——case1
for (i = 0; i < 10; i++) {
printf("%d ", arrInt[i]);
} //数组名还有另外一层含义:数组首地址(可以加*解引用来访问值)
int *ptr = arrInt;
printf("%d\n", *ptr); //输出了arrInt[0] --> 1
//遍历数组——case2
for (i = 0; i < 10; i++) {
printf("%d ", *(ptr++));
printf("%d ", *(arrInt + i));
//printf("%d ", *(arrInt++)); 不要尝试这么做
}
字符与字符串
//务必保证数组长度比字符数量多1,因为结束有一个\0
char arrCh1[6] = {'h', 'e', 'l', 'l', 'o', '\0'};
char arrCh2[] = {'h', 'e', 'l', 'l', 'o', '\0'};
char arrCh3[] = "hello"; //自动添加\0,推荐使用这种方法,可以不用指定长度。
char *arrCh4 = "hello world"; //声明一个字符型指针,指向字符串的首地址,推荐使用。 //注意strlen只会返回字符数组中,实际的字符数量(并不是声明的长度)
//所以arrCh1的长度是5,并不会将\0算在长度中
printf("%d\n", strlen(arrCh1)); //5
printf("%d\n", strlen(arrCh2)); //5
printf("%d\n", strlen(arrCh3)); //5
printf("%d\n", strlen(arrCh4)); //11 //遍历字符数组(字符串)
int i = 0;
while (arrCh1[i] != '\0') {
printf("%c ", arrCh1[i++]);
} //直接输出字符串。因为数组名是字符串的首地址,那么就可以直接输出了
//注意不用加*
printf("%s\n", arrCh1);
printf("%s\n", arrCh2);
printf("%s\n", arrCh3);
printf("%s\n", arrCh4);
声明并创建结构体
#include<stdio.h>
#include<stdlib.h>
struct Person {
//int age = 10; 不能设置默认值
int age;
char *name;
}; //末尾加分号
int main()
{
//创建结构体变量的时候,前面不止要加结构体名,还要加struct关键字
struct Person p;
p.age = 10;
p.name = "abcdefg";
printf("%d %s\n", p.age, p.name); //结构体指针
struct Person *ptr;
ptr = (struct Person*)malloc(sizeof(struct Person));
ptr->age = 20;
ptr->name = "xyzdddddd";
printf("%d %s\n", ptr->age, ptr->name);
free(ptr);
return 0;
}
共用体
#include<stdio.h>
#include<string.h> //这个union只占用10个字节空间
union Info {
int age;
char name[10];
char addr[10];
};
int main()
{
//声明共用体实例同样要使用union关键字加上共用体名称
union Info t;
t.age = 10;
printf("%d\n", t.age); //给字符数组赋值可以使用strcpy(dest, source)
strcpy(t.name, "hello");
printf("%s\n", t.name); //此时age的数据已经被清除了。因为他们共用一段空间
printf("%d\n", t.age);
return 0;
}
typedef和define
#include<stdio.h> //define用来定义常量,语句末尾不加分号
#define ONE "1111111"
//define是预编译器处理 //typdef用来声明别名,语句末尾要加分号
typedef int* ptr;
//typedef是编译器处理 int main()
{
int a = 10;
ptr b = &a; //使用新定义的类型
printf("%s\n", ONE); //输出常量
printf("%d\n", *b);
return 0;
}
隐式类型转换
注意在类型转换的时候,精度丢失的问题。
#include<stdio.h>
int main()
{
double dd = 10.0001;
int ii = dd; //隐式转换。
printf("%d\n", ii); //10
printf("%f\n", dd); //10.0001
//printf("%d\n", dd); //错误用法。注意不会发生类型转换 int i = 10;
double d = i / 3.0; //隐式转换
printf("%f\n", d); //3.333333
return 0;
}
强制类型转换
注意在类型转换的时候,精度丢失的问题。
#include<stdio.h>
#include<stdlib.h>
struct Person {
int age;
char *name;
};
int main()
{
double dd = 100.0001;
int a = dd; //隐式转换
double b = (double)a; //强制类型转换
printf("%d\n", a);
printf("%f\n", b); //强制类型转换
struct Person *p = (struct Person*)malloc(sizeof(struct Person));
return 0;
}
函数
函数可以定义为无返回值(void),或者有返回值(int、char.....)
无返回值的函数
#include<stdio.h> //打印数组
void PrintArr(int *a, int length){
int i;
for (i = 0; i < length; i++){
printf("%d ",a[i]);
}
}
int main()
{
int a[] = {9,8,7,6,5,4,3,2,1};
int length = sizeof(a) / 4;
PrintArr(a, length);
return 0;
}
有返回值的函数
#include<stdio.h> int is_odd(int a){
return a&1;
}
int main()
{
printf("%d\n", is_odd(2)); //0
printf("%d\n", is_odd(3)); //1
return 0;
}
实现数据结构与算法需要掌握的C语言的更多相关文章
- 数据结构与算法之顺序栈C语言实现
顺序栈是一种特殊的顺序表,主要操作是入栈和出栈.将顺序表加一些特定限制,就成了顺序栈. 注: 1.顺序栈C语言实现: 2.按较简单的方式实现,主要帮助理解,可在此基础上修改,更加完善: 3.提供几个简 ...
- 数据结构与算法之顺序表C语言实现
顺序表等相关概念请自行查阅资料,这里主要是实现. 注: 1.顺序表C语言实现: 2.按较简单的方式实现,主要帮助理解,可在此基础上修改,更加完善: 3.提供几个简单函数,可自行添加功能: 4.可用C+ ...
- python数据结构与算法
最近忙着准备各种笔试的东西,主要看什么数据结构啊,算法啦,balahbalah啊,以前一直就没看过这些,就挑了本简单的<啊哈算法>入门,不过里面的数据结构和算法都是用C语言写的,而自己对p ...
- Java数据结构和算法 - OverView
Q: 为什么要学习数据结构与算法? A: 如果说Java语言是自动档轿车,C语言就是手动档吉普.数据结构呢?是变速箱的工作原理.你完全可以不知道变速箱怎样工作,就把自动档的车子从1档开到4档,而且未必 ...
- 用Python实现的数据结构与算法:开篇
一.概述 用Python实现的数据结构与算法 涵盖了常用的数据结构与算法(全部由Python语言实现),是 Problem Solving with Algorithms and Data Struc ...
- 开启基本数据结构和算法之路--初识Graphviz
在我的Linux刀耕开荒阶段,就想开始重拾C,利用C实现常用的基本数据结构和算法,而数据结构和算法的掌握的熟练程度正是程序的初学者与职业程序员的分水岭. 那么怎么开启这一段历程呢? 按照软件工程的思想 ...
- 【转】MySQL索引背后的数据结构及算法原理
摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎对索引的支持也各不相同,因此MySQL数据库支持多种索引类型,如BT ...
- [转]MySQL索引背后的数据结构及算法原理
摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎对索引的支持也各不相同,因此MySQL数据库支持多种索引类型,如BT ...
- MySQL索引背后的数据结构及算法原理【转】
本文来自:张洋的MySQL索引背后的数据结构及算法原理 摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎对索引的支持 ...
随机推荐
- C# -- 使用递归列出文件夹目录及目录下的文件
使用递归列出文件夹目录及目录的下文件 1.使用递归列出文件夹目录及目录下文件,并将文件目录结构在TreeView控件中显示出来. 新建一个WinForm应用程序,放置一个TreeView控件: 代码实 ...
- 【夯实Ruby基础】Ruby快速入门
本文地址: http://www.cnblogs.com/aiweixiao/p/6664301.html 文档提纲 扫描关注微信公众号 1.Ruby安装 1.1)[安装Ruby] Linux/Uni ...
- 关于折半法查找的一些总结以及ArrayList类的总结
一.折半法查找的总结(这算法很好理解,但我花了好久琢磨他有啥用.....) 1.实际意义 折半法查找主要是为了能够很快在一个数组中找出我们所需要的那个元素,与往常我们通过一个一个比较的方法不同,折半法 ...
- RPC入门总结(一)RPC定义和原理
转载:深入浅出 RPC - 浅出篇 转载:RPC框架与Dubbo完整使用 转载:深入浅出 RPC - 深入篇 转载:远程调用服务(RPC)和消息队列(Message Queue)对比及其适用/不适用场 ...
- re库
一.Re库的主要功能: 函数 功能 re.search() 在一个字符串中搜索匹配正则表达式的第一个位置,返回match对象 re.match() 在一个字符串的开始位置匹配正则表达式,返回match ...
- Deep Knowledge Tracing (深度知识追踪)
论文:Deep Knowledge Tracing Addressing Two Problems in Deep Knowledge Tracing via Prediction-Consis ...
- SpringBoot MVC 拦截器
SpringBoot MVC 环境搭建 在pom.xml添加spring-boot-starter-web <dependency> <groupId>org.spri ...
- js 文件引用传递参数
每天学习一点点 编程PDF电子书免费下载: http://www.shitanlife.com/code (function() {var hm = document.createElement(&q ...
- (0)HomeAssistant 教程
国外:https://www.home-assistant.io/components/light.mqtt/ 中国:https://www.hachina.io/docs/890.html
- js同步-异步-回调
出处:https://blog.csdn.net/u010297791/article/details/71158212(1)上面主要讲了同步和回调执行顺序的问题,接着我就举一个包含同步.异步.回调的 ...