从零开始,一切都还来的及
(看的北京大学C++视频课程,代码参考视频课程,版权归视频所有,此处敲代码并记录只为学习)
/*函数指针*/
#include<iostream>
using namespace std;
void PrintMin(int a,int b)
{
if(a<b)
{
cout << a;
}
else
{
cout << b;
}
}
int main()
{
void (*p)(int,int);
//定义一个指向返回值为void,参数列表为(int,int)的函数
int x = 4,y = 5;
p = PrintMin;
//让上述指针指向PrintMin函数
p(x,y);
return 0;
}
/*调用系统函数进行快排
讲解函数指针的用途
qsort的比较函数:
如果参数1排在参数2前面,返回负整数
如果怎么排都行,返回0
否则返回正整数
此程序按照个位数大小排序*/
#include<iostream>
#include<stdlib.h>
using namespace std;
const int NUM = 5;
int MyCompare(const void *elem1,const void *elem2)
{
unsigned int *p1,*p2;
p1 = (unsigned int*)elem1;
p2 = (unsigned int*)elem2;
return (*p1 % 10) - (*p2 % 10);
}
int main()
{
unsigned int n[NUM] = {8,123,11,10,4};
qsort(n,NUM,sizeof(unsigned),MyCompare);
for(int i = 0;i < NUM;i++)
{
cout << n[i] << endl;
}
return 0;
}