今日学习任务 | 函数、指针、数组之间的关系 |
今日任务完成情况 (详细说明本日任务是否按 计划完成,开发的代码量) | 按照计划和要求,完成当天的学习任务。 1、在老师的指点下,学习讨论前日布置的作业,进一步改进自己的代码。 2、函数与指针(函数指针变量) 例如:int(*pf)(); 表示pf是一个指向函数入口的指针变量,该函数的返回值是整型。 3、用函数指针写一个用于排序的程序 4、指针型函数 5、二维数组和指针运算 6、二维数组的两种访问方式 7、命令行参数 |
今日开发中出现的问题汇总 | 1、int(*p)()和int *p()的区别: 前者是一个变量说明,说明p是一个指向函数入口的指针变量,该函数的返回值是整型量,(*p)的两边的括号不能少;后者则不是变量说明而是函数说明,说明p是一个指针型函数,其返回值是一个指向整型量的大指针,*p两边没有括号,作为函数说明,在括号内最好写入形式参数,这样便于与变量说明区别,并且对于指针型函数定义,它只是函数头部分,一般还应该有函数体部分。 2、int*(*(*fp)(int))[10];和int*(*(*array[5])())();是什么意思? ① fp是一个指针指向函数,函数有一个int类型参数,函数的返回值是一个指针,指向一个有10个元素的数组,每个元素都是一个整型指针。 ② 函数指针函数指针数组,array是一个数组,有5个元素,每个元素都是指针,指向一个函数,函数没有形参,返回值是一个指针,指向一个函数,函数没有形参,返回值是一个整型指针。 3、用变量a给出下面的定义 e) int *a[10]; f) int (*a)[10]; g) int (*a)(int);h) int (*a[10])(int); |
今日未解决问题 | 暂无。 |
今日开发收获 | 1、在C语言中,一个函数总是占用一段连续的内存区,而函数名就是该函数所占内存区的首地址。把函数的这个首地址(或称入口地址)赋予一个指针变量,使该指针变量指向该函数。然后通过指针变量就可以找到并且调用这个函数,我们把这种指向函数的指针变量称为“函数指针变量”。 2、函数指针变量定义的一般形式为:类型说明符(*指针变量名)(); 3、在C语言中允许一个函数的返回值是一个指针(即地址),这种返回指针值的函数被称为指针型函数。定义指针型函数的一般形式为: 类型说明符*函数名(形参表) { ....../*函数体*/ } 其中函数名之前加了“*”号表面这书一个指针型函数,即返回值是一个指针。类型说明符表示了返回的指针值所指向的数据类型。 4、二维数组和指针 一个数组的元素值为指针则是指针数组。 指针数组的所有元素都必须是 具有相同存储类型和指向相同数据类型的指针变量。 指针数组说明的一般形式为:类型说明符*数组名【数组长度】其中类型说明符为指针值所指向的变量的类型。 例如:int*pa[3]; 表示pa是一个指针数组,它有三个数组元素,每个元素值都是一个指针,指向整型变量。 |
其他 | 世界会向那些有目标和远见的人让路~ |
#include "stdio.h"
#include "stdlib.h"
int main(void){
int n,x[20],i,j,k;
while(1){
printf("Input n(int n<=20)...\n");
if(scanf("%d",&n),n==0)
break;
for(i=0;i<n;scanf("%d",x+i++));
printf("\nAfter sorting as follows:\n");
for(i=0;i<n;i++){
for(k=i,j=k+1;j<n;j++)
if(x[k]>x[j]) k=j;
if(k!=i){
j=x[k];
x[k]=x[i];
x[i]=j;
}
printf(i<n-1 ? "%d " : "%d\n",x[i]);
}
}
return 0;
}