Puntero de C ++ a una matriz

Lo más probable es que no comprenda este capítulo hasta que haya revisado el capítulo Punteros de C ++ relacionados.

Entonces, asumiendo que tiene un poco de comprensión sobre los punteros en C ++, comencemos: un nombre de matriz es un puntero constante al primer elemento de la matriz. Por lo tanto, en la declaración:

double balance[50];

balancees un puntero a & balance [0], que es la dirección del primer elemento de la matriz balance. Por lo tanto, el siguiente fragmento de programa asignap la dirección del primer elemento de balance -

double *p;
double balance[10];

p = balance;

Es legal usar nombres de matrices como punteros constantes y viceversa. Por tanto, * (saldo + 4) es una forma legítima de acceder a los datos en saldo [4].

Una vez que almacena la dirección del primer elemento en p, puede acceder a los elementos de la matriz usando * p, * (p + 1), * (p + 2) y así sucesivamente. A continuación se muestra el ejemplo para mostrar todos los conceptos discutidos anteriormente:

#include <iostream>
using namespace std;
 
int main () {
   // an array with 5 elements.
   double balance[5] = {1000.0, 2.0, 3.4, 17.0, 50.0};
   double *p;

   p = balance;
 
   // output each array element's value 
   cout << "Array values using pointer " << endl;
   
   for ( int i = 0; i < 5; i++ ) {
      cout << "*(p + " << i << ") : ";
      cout << *(p + i) << endl;
   }
   cout << "Array values using balance as address " << endl;
   
   for ( int i = 0; i < 5; i++ ) {
      cout << "*(balance + " << i << ") : ";
      cout << *(balance + i) << endl;
   }
 
   return 0;
}

Cuando se compila y ejecuta el código anterior, produce el siguiente resultado:

Array values using pointer
*(p + 0) : 1000
*(p + 1) : 2
*(p + 2) : 3.4
*(p + 3) : 17
*(p + 4) : 50
Array values using balance as address
*(balance + 0) : 1000
*(balance + 1) : 2
*(balance + 2) : 3.4
*(balance + 3) : 17
*(balance + 4) : 50

En el ejemplo anterior, p es un puntero a double, lo que significa que puede almacenar la dirección de una variable de tipo double. Una vez que tenemos la dirección en p, entonces*p nos dará el valor disponible en la dirección almacenada en p, como hemos mostrado en el ejemplo anterior.