任尔东南西北风
露露最棒。
加油
##概念总结
1.sizeof和strlende:
strlen是用来计算字符串的长度,遇到第一个NULL(’\0’)为止,不包括‘\0’;
sizeof是用来计算变量或者对象、类型所占字节的多少;
sizeof是一个关键字不是函数,发生在编译时刻,所以可以用作常量表达式;
strlen是一个函数,并且所传入的参数必须是char*,发生在运行时刻;
sizeof只关心这块内存的大小,不关心这块内存存放了什么数据;
strlen只关心这块内存存放的数据,不关心这块内存的大小,直到遇到第一个NULL为止。
2struct:
结构是由基本数据类型构成的、并用一个标识符来命名的各种变量的组合。
结构中可以使用不同的数据类型。 注意typedef struct取别名。
ypedef struct person {
int age ;
char *name;
char *sex;
} student;
我们可以用student来定义一个结构体变量:student stu1;typedef的作用就相当于给你struct person取了一个别名,如果我们不用typedef定义我们就不能用student定义,此时student就是一个结构体变量,如果要定义结构体变量的话就得用struct person来定义 struct person stu1.
3.static:
第一、在修饰变量的时候,static修饰的静态局部变量只执行一次,而且延长了局部变量的生命周期,直到程序运行结束以后才释放。
第二、static修饰全局变量的时候,这个全局变量只能在本文件中访问,不能在其它文件中访问,即便是extern外部声明也不可以。
第三、static修饰一个函数,则这个函数的只能在本文件中调用,不能被其他文件调用。Static修饰的局部变量存放在全局数据区的静态变量区。初始化的时候自动初始化为0; (1)不想被释放的时候,可以使用static修饰。比如修饰函数中存放在栈空间的数组。如果不想让这个数组在函数调用结束释放可以使用static修饰 (2)考虑到数据安全性(当程想要使用全局变量的时候应该先考虑使用static)
今日练习
1.递归输出1234的每一位:
#include <stdio.h>
void print(int n) //递归
{
if (n>9)
{
print(n / 10);
}
printf("%d ", n % 10);
}
int main()
{
int num = 1234;
print(num);
return 0;
}
2.递归和非递归分别实现求第n个斐波那契数。
//#define _CRT_SECURE_NO_WARNINGS 1
//#include<stdio.h>
//#include<stdlib.h>
//int Fib(int n)
//{
// if (n <= 2)
// {
// return 1;
// }
// else
// {
// return(Fib(n - 2) + Fib(n - 1));
// }
//}
// int main()
// {
// int n = 0;
// printf(“打印波那契数”);
// scanf("%d", &n);
// printf("%d", Fib(n));
// system(“pause”);
//
// return 0;
// }
//#define _CRT_SECURE_NO_WARNINGS 1
//#include<stdio.h>
//#include<stdlib.h>
//int main()
//{
// int a = 1;
// int b = 1;
// int c = 0;
// int n = 0;
// scanf("%d", &n);
// if (n <= 2)
// {
// printf("这个数为%d", a);
//
// }
// while (n>2)
// {
// c = a + b;
// a = b;
// b = c;
// n--;
// }
// printf("%d", c);
// system("pause");
// return 0;
//}
3.递归数组问题:
//#define _CRT_SECURE_NO_WARNINGS 1
//#include<stdio.h>
//#include<stdlib.h>
//int main()
//{
// int a = 1;
// int b = 1;
// int c = 0;
// int n = 0;
// scanf("%d", &n);
// if (n <= 2)
// {
// printf("这个数为%d", a);
//
// }
// while (n>2)
// {
// c = a + b;
// a = b;
// b = c;
// n--;
// }
// printf("%d", c);
// system("pause");
// return 0;
//}
4.递归实现strlen函数:
//#include<stdio.h>
//#include<assert.h>
//#include<stdlib.h>
//int my_strlen(const char *p)
//{
// assert(p != NULL);
// if (*p == ‘\0’)
// {
// return 0;
// }
// else
// {
// return 1 + my_strlen(p + 1);
// }
//}
//int main()
//{
// char *p = “abcdefg”;
// int ret = my_strlen§;
// printf("%d\n", ret);
// system(“pause”);
// return 0;
//}