当前位置:首页 > C++知识 > 正文内容

指针(二):指针与数组

亿万年的星光3年前 (2021-08-10)C++知识19320

1.指针与数组的关系

    指向数组的指针变量称为数组指针变量。“数组是内存上一块连续的空间”。数组名就是这块连续空间的首地址。


2.指针指向数组


    一开始的数组定义与输出:

#include<iostream>
#include<cstdio>
using namespace std;
int main(){
	int a[10];
	for(int i=0;i<5;i++){
		cin>>a[i];
	}
	for(int i=0;i<5;i++){
		cout<<a[i]<<" ";
	}
	return 0;
}

指针操作也可以输入数据:

#include<iostream>
#include<cstdio>
using namespace std;
int main(){
	int a[10];
	for(int i=0;i<5;i++){
		scanf("%d",a+i); //本来写成scanf("%d",&a[i]); 
	}
	for(int i=0;i<5;i++){
		printf("%d ", *(a+i));  //
	}
	return 0;
}

上面这个操作,本来scanf("%d",&a)写法,其中&是取地址符,a是数组名,本来就表示数组空间的首地址,所以可以直接用。注意,这个地方不能用cin。

数组指向指针操作:

我们可以定义指针变量,让它来指向数组名。

#include<iostream>
#include<cstdio>
using namespace std;
int main(){
	int a[10];
	int *p=a;  
	for(int i=0;i<5;i++){
		scanf("%d",p+i); //本来写成scanf("%d",&a[i]); 
	}
	for(int i=0;i<5;i++){
		printf("%d ", *(p+i)); 
	}
	return 0;
}

2.指针的加减

指针也是变量,可以加减。

#include<iostream>
#include<cstdio>
using namespace std;
int main(){
	int a[10]={1,2,3,4,5};
	int *pa=a;  
	cout<<a[0]<<endl; //结果是1 
	cout<<pa<<endl;   //0x70fdf0
	cout<<*pa<<endl;  //结果是1
	
	pa++;
	cout<<pa<<endl; //0x70fdf4
	cout<<*pa<<endl;  //2
	
	pa=pa+2;
	cout<<pa<<endl; //0x70fdfc
	cout<<*pa<<endl;  //4
	
	pa--;
	cout<<pa<<endl; //0x70fdf8
	cout<<*pa<<endl;  //3 
	return 0;
}


扫描二维码推送至手机访问。

版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

分享给朋友:

相关文章

【高级篇】C++中的sort函数详解

【高级篇】C++中的sort函数详解

0.简介sort函数用于C++中,对给定区间所有元素进行排序,默认为升序,也可进行降序排序。sort函数进行排序的时间复杂度为n*log2n,比冒泡之类的排序算法效率要高,sort函数包含在头文件为#...

【算法】前缀和与差分(3)二维数组前缀和

【算法】前缀和与差分(3)二维数组前缀和

0.前言前面的一篇文章,介绍了一维数组的前缀和,这篇文章中,介绍一下二维数组的前缀和1.定义二维数组的前缀和就是按照二维数组求和。公式如下:那二维前缀和中一个f[i][j]表示的意思就是以(1,1)为...

unsigned

在一些代码中,经常能看到unsigned这种数据类型,比如下面这样的。#include<iostream> using namespace std; int&nbs...

【数论】二项式定理

【数论】二项式定理

一、基本概念上面这个式子就叫做二项式定理,又称牛顿二项式定理,该定理给出两个数之和的整数次幂诸如展开为类似项之和的恒等式。二项式定理可以推广到任意实数次幂,即广义二项式定理。 初中高中阶段比...

质数(素数)的判断

一、定义法// 1 定义法(除了1和他本身之外,没有任何一个数能被整除)(试除法) bool is_prime3(unsigned long lon...

【题解】最短路径问题

【题目描述】平面上有n个点(n≤100),每个点的坐标均在-10000~10000之间。其中的一些点之间有连线。若有连线,则表示可从一个点到达另一个点,即两点间有通路,通路的距离为两点间的直线距离。现...