二维数组指针,指针数组,指针函数

指针 操作 二维字符型数组

定义:

char s[ ][10] = {"hello","world","china"};

char (*p)[10] = s; //p指向二维数组s

练习:

输入三个字符串 ,排序输出

cs 复制代码
#include <stdio.h>
#include <string.h>

void putStr(char (*p)[20],int row)
{
	int i = 0;
	for (i = 0; i < 3; ++i)
	{
		printf("%s \n",*(p+i));
	}
}

void choiceSort(char (*p)[20],int row)
{
	int i = 0;
	int j = 0;
	for (i = 0; i < row-1; ++i)
	{
		for (j = i+1; j < row; ++j)
		{
			if (strcmp(*(p+i),*(p+j)) > 0)
			{
				char t[20];
				strcpy(t,*(p+i));
				strcpy(*(p+i),*(p+j));
				strcpy(*(p+j),t);
			}
			
		}
	}
}
	

int main(void)
{
    char s[][20] = {"hello","world","china"};
	
	putStr(s,3);
	choiceSort(s,3);
	puts("------------------\n");
	putStr(s,3);

	return 0;
}

指针的数组

1.先看以下3个初始化

char *p1 = "hello";

char *p2 = "world";

char *p3 = "china";

p1,p2,p3分别指向字符串常量区中"hello","world","china"不能被修改,

我们可以将上面3个写在一起组成一个指针数组:

char* pstr[3]= {"hello","world","china"}; 数组中存放是 各个字符串的地址

2.函数中使用指针数组,形参形式为(char **p)

char **p:数组指针的指针,基类型是char*

3.练习:

逆序,冒泡排序

cs 复制代码
#include <stdio.h>
#include <string.h>

void printStr(char * *p,int len)
{
	int i = 0;
	for (i = 0; i < 3; ++i)
	{
		printf("%s\n",*(p+i));
	}

}

void reverseStr(char **begin, char **end)
{
	while (begin < end)
	{
		char *t = *begin;
		*begin = *end;
		*end = t;

		begin++;
		end--;
	}
}

void bubbleSort(char **p,int len)         //冒泡排序
{
	int i = 0;
	int j = 0;

	for (i = len-1; i > 0; --i)
	{
		for (j = 0; j < i; ++j)
		{
			if (strcmp(*(p+j),*(p+j+1)) > 0)
			{
				char *t = *(p+j);
				*(p+j) = *(p+j+1);            //值不能被改变,交换地址
				*(p+j+1) = t ;
			}
		}
	}
}


int main(void)
{
	const char *p[] = {"hello","world","china"};
	printStr(p,3);
	reverseStr(p,p+2);
	bubbleSort(p,3);
	puts("---------------");
	printStr(p,3);
	return 0;
}

指针 + 函数

1.通过指针 的方式 来调用函数

函数名 --- 代表函数的入口地址

i nt add(int a,int b) // 函数

// 函数名 - 代表函数的入口地址

// 函数名对应的数据类型:int (int a,int b)

int (int a,int b) // 代表一类函数

// 返回值为int型

// 带有两个int型的形参变量

函数的指针应该写成 int(*p)(int,int) 这样的形式

函数的调用:p(a,b);

说明:

1.可以定义一个函数类型的指针变量

来保存函数的入口地址

2.有了这个指针变量

通过指针变量 进行函数调用

cs 复制代码
#include <stdio.h>

int add(int a,int b)
{
	return a + b;
}
int main(void)
{
   int (*p) (int,int) = add;          //理解:int(int,int) *p
   int ret = p(1,2);
   printf("ret = %d\n",ret);

}

2.函数回调

回调函数 --- 通过函数指针调用函数 就是回调

c语言中,使用了 函数指针 实现回调

练习:

写一个程序 实现加,减,乘,除

以回调函数的形式,打印对应的结果

cs 复制代码
#include<stdio.h>
void proscessDate(int a,int b,int(pfunc)(int,int))
{
	int n;
	n=pfunc(a,b);
	printf("%d\n",n);
}

int add(int a,int b)
{
	return a+b;
}
int Chu(int a,int b)
{
	return a/b;
}

int Jian(int a,int b)
{
	return a-b;
}
int Cheng(int a,int b)
{
	return a*b;
}

int main(void)
{
	int a,b;
	scanf("%d%d",&a,&b);
	proscessDate(a,b,Cheng);
}
相关推荐
yuanbenshidiaos3 分钟前
C++----------函数的调用机制
java·c++·算法
唐叔在学习7 分钟前
【唐叔学算法】第21天:超越比较-计数排序、桶排序与基数排序的Java实践及性能剖析
数据结构·算法·排序算法
兔C17 分钟前
微信小程序的轮播图学习报告
学习·微信小程序·小程序
海海不掉头发25 分钟前
苍穹外卖-day05redis 缓存的学习
学习·缓存
ALISHENGYA26 分钟前
全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之分支结构(switch语句)
数据结构·算法
chengooooooo28 分钟前
代码随想录训练营第二十七天| 贪心理论基础 455.分发饼干 376. 摆动序列 53. 最大子序和
算法·leetcode·职场和发展
jackiendsc35 分钟前
Java的垃圾回收机制介绍、工作原理、算法及分析调优
java·开发语言·算法
FeboReigns1 小时前
C++简明教程(文章要求学过一点C语言)(1)
c语言·开发语言·c++
FeboReigns1 小时前
C++简明教程(文章要求学过一点C语言)(2)
c语言·开发语言·c++
小木_.1 小时前
【Python 图片下载器】一款专门为爬虫制作的图片下载器,多线程下载,速度快,支持续传/图片缩放/图片压缩/图片转换
爬虫·python·学习·分享·批量下载·图片下载器