输出矩阵:
#include <stdio.h>
void main(void)
{
int i;
int j;
int num1;
int num2;
int data[][4] = {{1,2,3,4}, {4,5,6,7}, {8,9,10,11}};
num1 = sizeof(data) / sizeof(data[0]);
num2 = sizeof(data[0]) / sizeof(int);
printf("num1 = %d\n",num1);
printf("num2 = %d\n",num2);
for(i = 0; i < num1; i++) {
for(j = 0; j < num2; j++) {
printf("%5d",data[i][j]);
}
printf("\n");
}
}
二级指针做形参
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
void f(int **p)
{
p = (int)malloc(sizeof(int)*8);
if(*p == NULL)
return;
p = NULL;
}
void main(void)
{
int *p;
f(&p);
*p = 10;
printf("%d\n",p[0]);
free§;
p = NULL;
}
二维数组:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
void main(void)
{
int data[][4] = {{1,2,3,4}, {4,5,6,7}, {8,9,10,11}};//data为一个行指针
printf("%p\n",data);//0行首地址
printf("%p\n",data);//0行第一个元素的地址
printf("%p\n",&data);
printf("(data) = %d\n",(data));
printf("(data) = %d\n",((*data) + 1));
printf(“data[0][0] = %d\n”,data[0][0]);
printf("*data[1] = %d\n",data[1]); //data[1]为data[1][0]的地址
printf("(data[1]+1) = %d\n", *(data[1] + 1));
}
指针数组:
#include <stdio.h>
void main(void)
{
int a[3] = {1,2,3};
int b[3] = {4,5,6};
int *p[2] = {a,b};
printf("**p = %d\n", **p);
printf("((p)+1) = %d\n",((p)+1));
printf("(p[0]) = %d\n", *(p[0]));
}
数组指针:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
void main(void)
{
//int (p)[3] = {1,2,3};//错误能直接给一个数组赋值
int (p)[3];//定义一个有三个元素的数组指针类型 p是一个二级指针,指向数组
int data[][3] = {{1,2,3},{4,5,6},{7,8,9}};
p = data;
p = &data[0];
printf("(p +1) = %d\n",(p +1));
printf("(p[0] + 1) = %d\n",(p[0] + 1));
}