1.程序的功能是用指针变量作函数参数编程计算任意m×n阶矩阵的转置矩阵。要求用指向一维数组的指针变量即二维数组的行指针作函数参数。
程序的运行结果如下:
Please enter matrix:
1 2 3 4↙
1 2 3 4↙
1 2 3 4↙
The transposed matrix is:
1 1 1
2 2 2
3 3 3
4 4 4
#include <stdio.h>
#define ROW 3
#define COL 4
void Transpose(int (*a)[COL], int (*at)[ROW], int row, int col);
void InputMatrix(int (*s)[COL], int row, int col);
void PrintMatrix(int (*s)[ROW], int row, int col);
int main(void)
{
int s[ROW][COL];//s代表原矩阵
int st[COL][ROW];//st代表转置后的矩阵
printf("Please enter matrix:\n");
InputMatrix(s, ROW, COL);//输入原矩阵,s指向矩阵s的第0行,是行指针
Transpose(s, st, ROW, COL);//对矩阵s进行转置,结果存放于st中
printf("The transposed matrix is:\n");
PrintMatrix(st, COL, ROW); //输出转置矩阵,*st指向st的第0行,是行指针
return 0;
}
//函数功能: 对任意row行col列的矩阵a转置,转置后的矩阵为at
void Transpose(int (*a)[COL],int (*at)[ROW], int row, int col)
{
int i, j;
for (i=0; i<row; i++)
{
for (j=0; j<col; j++)
{
*(*(at+j)+i)=*(*(a+i)+j);
}
}
}
void InputMatrix(int (*s)[COL], int row, int col) //输入矩阵元素
{
int i, j;
for (i=0; i<row; i++)
{
for (j=0; j<col; j++)
{
scanf("%d", *(s+i)+j);// 元素s[i][j]
}
}
}
void PrintMatrix(int (*s)[ROW], int row, int col) //输出矩阵元素
{
int i, j;
for (i=0; i<row; i++)
{
for (j=0; j<col; j++)
{
printf("%d\t", *(*(s+i)+j)); // 元素s[i][j]
}
printf(" \n");
}
}
指针数组的原理:
2.字符指针数组排序
#include <stdio.h>
#include <string.h>
int main( )
{
int i,j;
static char *str[4]={"Program","Fortran","C","Basic"};
char *temp;
for(i=0;i<4;i++)
{
for(j=i+1;j<4;j++)
{
if(strcmp(str[i],str[j])>0) //冒泡法排序,但是效率更优
{
temp=str[j];
str[j]=str[i];
str[i]=temp;
}
}
}
for(i=0;i<4;i++)
printf("%s\n",str[i]);
return 0;
}
3.二级指针
不同指针的定义方式和适用场合