@新手露露的逆天成长@

任尔东南西北风

露露最棒。
加油

##概念总结

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;
//}





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值