提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
前面学习了vector和数组,接下来将学习c++中的函数和指针的相关的知识.
简言之,函数就是一组相关语句组成的一个具有某种功能实现的整体.
函数分为库函数和用户自定义函数;
例如在math.h中,就有fabs,pow,ceil,floor等函数.
而有些时候我们需要多次用到一种运算关系时,就会自定义一个函数,然后进行调用.
C语言:
#define _CRT_SECURE_NO_WARNINGS 1//visual studio编译器才会用,方便输入;
#include
int max(int a, int b)
{
return a > b ? a : b;
}
int main(void)
{
int a, b, c;
scanf("%d%d", &a, &b);
c = max(a, b);
printf("%d", c);
}
c++代码:
#include
using namespace std;
void max(int a, int b)
{
if (a > b)
{
cout << a;
}
else if (a < b)
{
cout << b;
}
cout << endl;
}
int main(void)
{
int a, b;
cin >> a >> b;
max(a, b);
}
在数学中我们常常会遇到函数分类讨论,根据变量的取值来对应不同的函数表达式,那我们如何用代码去实现喃?就要用到今天讲的递归和迭代;
此时我们用递归就可以解决。
代码如下(示例):
递归方法:
#include
using namespace std;
int f(int n)
{
if (n <= 2)
{
return 1;
}
else
{
return f(n - 1) + f(n - 2);
}
}
int main(void)
{
int n;
cin >> n;
int sum = f(n);
cout << sum << endl;
}
迭代:
#include
using namespace std;
int f(int n)
{
if (n <= 2)
{
return 1;
}
else
{
int fas1 = 1, fas2 = 1, ans;
for (int i = 3; i <= n; i++)
{
ans = fas1 + fas2;
fas1 = fas2;
fas2 = ans;
}
return ans;
}
}
int main(void)
{
int n;
cin >> n;
int c = f(n);
cout << c << endl;
}
编译预处理主要包含宏定义,文件包含和条件编译,以#开始,不需要分号结束;
利用关键字define,定义一个宏,可以是变量,也可以是参数;
文件包含是指将一些头文件或其他源文件包含到本文件中,一个文件被包含后,该文件的所有内容就被包含进来了,
#include<文件名>
#include"文件名"
尖括号和双引号的区别:
用尖括号时,称为标准模式,系统直接到存放c/c++库函数的文件中查找要包含的文件。用双引号的时候,系统优先在当前目录中查找要包含的头文件,若找不到,再按标准模式查找。一般来说使用库函数的时候用尖括号,使用用户自定义的头文件时,用双引号;
条件编译是以带#的if语句(有#if,$ifdef,#ifndef,#elif等多种形式)以#endif结束。
1.变量的定义
也可以用关键字typedef类型定义类型别名;
只有定义了变量后才会分配空间;
2.变量的初始化;
#include
using namespace std;
struct Student
{
char name[20];//姓名
double score;//成绩
char sex[10];//性别;
};
int main(void)
{
int n;
Student *s=(Student*)malloc(sizeof(Student));//申请动态存储空间;
cin >> n;
for (int i = 0; i < n; i++)
{
cin >> s[i].name >> s[i].score >> s[i].sex;
}
cout << "学生的姓名" << " " << "学生的成绩" << " " << "学生的性别" << endl;
for (int i = 0; i < n; i++)
{
cout << s[i].name << " " << s[i].score << " " << s->sex << endl;
}
}
指针变量是专门用来存放另一个变量的地址的变量,指针变量的值是指针中存放的变量的值。
前面我们介绍了vector,今天我们也可以用动态堆区内存申请以达到和vector相同的作用.
题目要求:首先输入一个n的值,然后输入n个学生的成绩,求出高于平均成绩的学生的人数。
解题思路:因为我们不知道n的值,故不能直接定义叔祖的长度,这个时候就可以用vector(向量)或者动态空间内存分配;注意内存空间分配完后,需要删除动态空间的内存;
2.读入数据
代码如下(示例):
#include
using namespace std;
int solve(int a[], int n)
{
int sum = 0, cnt = 0;
for (int i = 0; i < n; i++)
{
sum += a[i];
}
for (int i = 0; i < n; i++)
{
if (a[i] > 1.0 * (sum) / n)
{
cnt++;
}
}
return cnt;
}
int main(void)
{
int n;
cin >> n;
int* a = new int[n];//动态空间申请;
for (int i = 0; i < n; i++)
{
cin >> a[i];
}
int c = solve(a, n);
cout << c << endl;
delete [] a;
}
指针变量可以作为函数参数,当指针变量为形参的时候,通过改变形参的间接引用来改变实参的值.
l例如:
void f(int a[ ],int n)
{
函数体;
}
等价于
void f(int*a,int n)
{
函数体;
}
#include
using namespace std;
int swa(int* a, int* b)
{
return *a > *b ? *a : *b;
}
int main(void)
{
int a, b;
int c;
cin >> a >> b;
c=swa(&a, &b);
cout << c << endl;
}
本节介绍了指针和函数,指针无论在c语言中还是c++中都是一种重要的知识点,需要花大量时间去实际操作,下一期更新数据结构STL中的list(链表);