物联1234DX锋
1. 存在定义 int a[10], x, *pa; , 若 pa = &a[0] , 下列的哪个选项和其他3个选项不是等价的?( A )
A. x = *pa; a[0]
B. x = *(a+1); a[1]
C. x = *(pa+1); a[1]
D. x = a[1]; a[1]
2. 请问下列程序的执行结果是 ___6 2 3 4 5 ___。
void fun(int *p, int n)
{
int i;
for(i = 0; i < n; i++)
(*p)++;
} //使a[0]自增五次,即令a[1]为6。int main()
{
int a[5] = {1, 2, 3, 4, 5},i;
fun(a,5);
for(i = 0; i < 5; i++)printf("%d ", a[i]);
return 0;
}
3. 以下哪个选项是C语言中获取指针所指向的值的正确方式?(排除法)( D )
A. *p = p;
B. *p = &p;
C. *p = p->value;
D. *p = p[0];
4. 对于下面代码, *p 是___5___。
int a[5] = {2, 3, 4, 5, 6}, *p = &a[2] + 1; //*p == a[3] //a[3] == 5
5. 函数调用程序如下:
void f(int a[], int n)
{
int i;
for(i=0;i<n;i++)
a[i]=i;
}
int main( )
{
int a[100],n=30;
f(a,n);...
}
相关说法错误的是:( D )
A. f 函数头改为 int f(int *a, int n) ,无需其它改变,效果完全一样。
B. main 函数中增加 int *p=a; 将 f(a,n); 改为 f(p,n); ,效果完全一样。
C. 用数组名作 f() 的参数,则 main() 中的数组与 f() 中的数组是同一数组。
D. 用数组名作 f() 的参数,实现了实参与形参双向的值传递。 从实参到形参单向传递
6. 以下程序段的输出结果为___
000000000062FDF0,000000000062FDF0,000000000062FDF0,000000000062FE14,19,1
___。
int a[] = {10,9,8,7,6,5,4,3,2,1}, *p;
p = a;
printf("%p,%p,%p,%p,%d,%d\n", a, &a, p, p+9, *p+9, *(p+9) );
a代表整个数组,值为数组的起始地址;&a取整个数组的地址,值为数组首元素地址;p指向数组首元素的地址;p+9指向数组第十个元素的地址。
*p+9为数组首元素加9;*(p+9)为数组第十个元素。
7. 参考学习通上传的PPT「第9章 指针」,仿照【例9.6】实现两个double数值的互换,使用「指针+函数」。要求:使用两种方法,其中第一种方式是交换值(PPT第28页)、第二种方式是交换指针(PPT第33页)。
//代码1:交换值的方法如下....
#include <stdio.h>
#include <stdlib.h>
int main() {
double num1=5, num2=9;
Swap(&num1, &num2);
printf ("num1=%lf,num2=%lf", num1, num2);
return 0;
}
void Swap(double *x, double *y) {
double temp;
temp = *x;
*x = *y;
*y = temp;
}
//代码2:交换指针的方法如下....
#include <stdio.h>
#include <stdlib.h>
int main() {
double num1=5, num2=9;
Swap(&num1, &num2);
printf ("num1=%lf,num2=%lf", num1, num2);
return 0;
}
void Swap(double **x, double **y) {
double *pTemp;
pTemp = *x;
*x = *y;
*y = pTemp;
}
8. 附加题 编写程序,输入5个实数(不一定是 int ),使用指针引用的方式将它们按从大到小的顺序排列。
(建议使用选择法/冒泡法,只要能体现指针引用即可,不强制要求所有代码都要使用指针)
输入示例:3.2 5.4 6.12 2.51 4.23 (说明:空格隔开)
输出示例:6.12 5.40 4.23 3.20 2.51 (说明:保留2位小数)
#include <stdio.h>
#include <stdlib.h>
int main() {
double num[5];
double *p = num;
int i;
for (i=0; i<5; i++) {
scanf ("%lf",p+i);
}
int j;
double temp;
for (i=0; i<4; i++) {
for (j=i+1; j<5; j++) {
if (*(p+i)<*(p+j)) {
temp = *(p+i);
*(p+i) = *(p+j);
*(p+j) = temp;
}
}
} //冒泡法。
for (i=0; i<5; i++) {
printf ("%.2lf ",*(p+i));
}
return 0;
}