const
(1)const修饰*,代表指针所指向的内存是只读。
例:const int * p2=&a; 或者是 int const * p2=&a
如果你要 *p2=100; //error
p2=NULL ; //ok
(2)const修饰指针变量,代表指针变量的值为只读
int * const p4 =&a;
*p4=100 ; //ok
p4=NULL //error
通过指针的加法来操作数组
练习题
#include<iostream>
using namespace std;
//正序输出
int main(){
int a[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
//定义一个指针,指向首元素
int * p = a;
p = &a[0];
int n = sizeof(a) / sizeof(*a);
int i = 0;
for (int i = 0; i < n; i++){
//printf("%d ", *p);
cout << *p << " ";
p++;
}
cout << '\n';
//定义一个指针,指向尾元素
int * q;
q = &a[n - 1];//q = a + n - 1;
for (int i = 0; i < n; i++){
cout << *q << ' ';
q--;
}
cout << '\n';
system("pause");
return 0;
}
打印结果 :1 2 3 4 5 6 7 8 9 10
10 9 8 7 6 5 4 3 2 1
例:有一个数组 找出第二大的数。并且不能排序后打印,使用指针操作数组
分析 :
我们可以这样来做,我们可以先找两个值,一个做最大值max,一个做第二小值smax,然后再进行比较,如果大于最大值,就将那个数赋值给最大值max,如果小于那个数,就和第二大值比较。
如果大于第二大值,就把他赋值给第二大值smax ,如果小于的话,则最大最小不变。
#include<iostream>
using namespace std;
void print(int * a, int len);
void get_thecond_num(int * a, int len, int max, int smax);
int main(){
int a[] = { 1, 4, 5, 9, 7, 6, 2 };
int len = sizeof(a) / sizeof(a[0]);
int max, smax;
if (*(a + 0) > *(a + 1)){
max = *(a + 0);
smax = *(a + 1);
}
else {
max = *(a + 1);
smax = *(a + 0);
}
get_thecond_num(a,len,max,smax);
system("pause");
return 0;
}
void get_thecond_num(int * a,int len, int max,int smax){
for (int i = 2; i < len; i++){
if (a[i]>max){
smax = max;
max = a[i];
}
else if (a[i]>smax && a[i]<max){
smax = a[i];
}
}
printf("smax=%d max=%d",smax,max);
}