今天学习了枚举,联合体,递归,重点在于递归,所以从网上找到了一些递归的题目进行练习,毕竟程序员界流传一句话,会用循环的是人,会用递归的是神,哈哈哈

还是按次序进行梳理,第一个枚举,枚举和宏定义很相似,好处就是不易修改,并且可以定下范围,例如在游戏中前后左右就固定用 键盘上的上下左右键表示,而不是用随便的四个按键就能代替;

 1 enum AA{上,下,左,右}; 声明就像这样,AA为枚举类型名,大括号内可以赋任何值,但是不推荐用中文,先不说有些标准内不识别中文的问题,中间的逗号来回切换就很麻烦,大括号内如果不给赋值的话,默认从零开始,依次向后自加1,例如这个声明 上 = 0,下 = 1,左 = 2依次类推。

 

第二个联合体,联合体和结构体形式上有些相似,比如 联合体名.变量名 可以取到变量的内容等等,但有着本质上的区别,先看声明

1 #include<stdio.h>
2 union AA
3 {
4     int a;
5     char c;
6     short b;
7 };

首先就是内存上的区别,联合体共用一个空间,共用体内最大内存变量的空间,例如这个联合体的内存大小就是4个字节,也就是int的字节数

但联合体的用处,我现在暂时只发现了一个,可以用来证明pc个人机的小端存储(其他后续再发掘)

 1 #include<stdio.h>
 2 union var{
 3         char c[4];
 4         int i;
 5 };
 6  
 7 int main(){
 8         union var data;
 9         data.c[0] = 0x04;//因为是char类型,数字不要太大,算算ascii的范围~
10         data.c[1] = 0x03;//写成16进制为了方便直接打印内存中的值对比
11         data.c[2] = 0x02;
12         data.c[3] = 0x11;
13 //数组中下标低的,地址也低,按地址从低到高,内存内容依次为:04,03,02,11。总共四字节!
14 //而把四个字节作为一个整体(不分类型,直接打印十六进制),应该从内存高地址到低地址看,0x11020304,低位04放在低地址上。
15         printf("%x\n",data.i);

结果是 11020304   从而证明了pc机低位存低端小端存储的特点;

 

第三个就是重点  递归  在学习中发现递归的难点在于,逻辑跳跃性大,一般的递归通过下断点调试还勉强可以发现错误,但是稍微复杂的递归就挺费事的了(比如接下来的通过递归实现字符串倒序),但是这么复杂的东西被发明出来还是有好处的,相对于循环来说节约了时间空间,速度快,但由于每一次调用都要开辟新的空间大大浪费了内存空间,而循环正好相反,这个以后可以根据项目特点来选择需要哪种方式。错了这么多题目,我总结出来写递归的两点就是1.肯定有函数的自我调用 2.设置好函数的出口点  ,打一个简单的比方把,如同分配任务,最高级一级级向下传递,一直传递到设置了函数出口点那一级,向逐级向上传递。

有这么一些题目,有对的,有错的,也有想了很长时间没想出来的,都罗列出来,今后作为一种参考

1.递归实现斐波那契数列

1 int FBNQDg(int n)
2 {
3     if(n == 1 || n == 2)
4         return 1;
5     return FBNQDg(n - 1) + FBNQDg(n - 2);
6 }

2.递归实现阶乘

1 int JieCheng(int n)
2 {
3     if(n == 1)
4         return 1;
5     return n * JieCheng(n - 1);
6 }

 

3.递归实现 字符串字符统计

1 int Strlen(char *str)
2 {
3     if(*str == '\0')
4         return 0;
5     return 1 + Strlen(++str);
6 }

 

4.通过递归实现一个数 各个位上的数相加(1729   1+7+2+9)

1 int DigitSum(int n)
2 {
3     if(n == 0)
4         return 0;
5     return n % 10 +  DigitSum(n / 10);
6 }

 

5.递归实现字符串倒序

 1 int my_strlen(char * arr)
 2 {
 3     char * end = arr;
 4     while (*end != '\0') {
 5         end++;
 6     }
 7     return end - arr;
 8 }
 9 void reverse_string(char * arr)
10 {
11     int len = my_strlen(arr);
12     int tmp = arr[0];
13     if (len <= 1) {
14         return ;
15     }
16     arr[0] = arr[len - 1];
17     arr[len - 1] = '\0';
18     reverse_string(arr + 1);
19     arr[len - 1] = tmp;
20 }

对了,递归有个最大的特点就是简洁(一般短小的都精悍)

 

2019-05-06 23:32:01 编程小菜鸟自我反省,大佬勿喷,谢谢!!!

posted on 2019-05-06 23:33  coding小菜鸟  阅读(175)  评论(0编辑  收藏  举报