C语言函数指针数组(简单应用)计算器

简介: C语言函数指针数组(简单应用)计算器

1.函数指针数组

存放函数指针的数组

格式: int (*parr1[10])();

解释:parr1首先和[]结合,说明parr1是数组,接着再和int(*)()结合,说明类型是函数指针。

2.简易版计算器

#include<stdio.h>
int Add(int x, int y)
{
  return x + y;
}
int Sub(int x, int y)
{
  return x - y;
}
int Mul(int x, int y)
{
  return x * y;
}
double Div(int x, int y)
{
  return x*1.0/ y;
}
void menu()
{
  printf("***********************************\n");
  printf("        1.Add       2.Sub          \n");
  printf("        3.Mul       4.Div          \n");
  printf("        0.Exit                     \n");
  printf("***********************************\n");
}
int main()
{
  int inpute = 0;
  int x, y;
  do
  {
    menu();
    scanf("%d", &inpute);
    switch (inpute)
    {
    case 1:
    {
      scanf("%d %d", &x, &y);
      int ret = Add(x, y);
      printf("%d\n", ret);
      break;
    }
    case 2:
    {
      scanf("%d %d", &x, &y);
      int ret = Sub(x, y);
      printf("%d\n", ret);
      break;
    }
    case 3:
    {
      scanf("%d %d", &x, &y);
      int ret = Mul(x, y);
      printf("%d\n", ret);
      break;
    }
    case 4:
    {
      scanf("%d %d", &x, &y);
      double ret = Div(x, y);
      printf("%lf\n", ret);
      break;
    }
    case 0:
    {
      printf("退出成功!\n");
      break;
    }
    default:
    {
      printf("输入错误请重新输入!\n");
      break;
    }
  }
  } while (inpute);
  return 0;
}

3.优化版计算器

简易版计算器在每个case语句部分会有大量的重复,这种被称为代码冗余,而我们可以通过函数指针数组来减少代码量,从而也能实现同样的功能。该代码只是简化了代码量,并没有优化其他部分

int Add(int x, int y)
{
  return x + y;
}
int Sub(int x, int y)
{
  return x - y;
}
int Mul(int x, int y)
{
  return x * y;
}
int Div(int x, int y)
{
  return x * 1.0 / y;
}
//简易的菜单
void menu()
{
  printf("***********************************\n");
  printf("        1.Add       2.Sub          \n");
  printf("        3.Mul       4.Div          \n");
  printf("        0.Exit                     \n");
  printf("***********************************\n");
}
int main()
{
  int (*pf[5])() = { 0,Add,Sub,Mul,Div }; 
  //利用函数指针数组来存储函数的地址
  int inpute = 0;//用于选择什么运算
  int x, y;  //操作数
  int ret; //用于接受返回值
  do
  {
    menu();
    scanf("%d", &inpute);
    if (inpute >= 1 && inpute <= 4)
    {
      printf("请输入计算的两个操作数:");
      scanf("%d %d", &x, &y);
      ret = (pf[inpute])(x, y);
      printf("%d\n", ret);
    }
    else if(inpute==0)
    {
      printf("退出成功!\n");
      break;
    }
    else
    {
      printf("选择错误,请重新输入:");
    }
  } while (inpute);
}

总结:函数指针数组虽然用的很少,但是有时候能帮助我们简化一定的代码量。

以上是函数指针数组的内容,如有问题,恳请大佬指点💖

目录
相关文章
|
3月前
|
存储 人工智能 程序员
一文彻底搞明白C语言的数组
本文详细介绍了C语言中的数组,包括定义、初始化(静态与动态)、存储方式、访问方法及常用操作,如遍历、修改元素和作为函数参数传递。数组是C语言中最基本的数据结构之一,掌握它对编程至关重要。下篇将介绍二维数组,敬请期待!
149 0
一文彻底搞明白C语言的数组
|
5月前
|
传感器 算法 安全
【C语言】两个数组比较详解
比较两个数组在C语言中有多种实现方法,选择合适的方法取决于具体的应用场景和性能要求。从逐元素比较到使用`memcmp`函数,再到指针优化,每种方法都有其优点和适用范围。在嵌入式系统中,考虑性能和资源限制尤为重要。通过合理选择和优化,可以有效提高程序的运行效率和可靠性。
390 6
|
6月前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
152 5
|
6月前
|
存储 程序员 编译器
C 语言数组与指针的深度剖析与应用
在C语言中,数组与指针是核心概念,二者既独立又紧密相连。数组是在连续内存中存储相同类型数据的结构,而指针则存储内存地址,二者结合可在数据处理、函数传参等方面发挥巨大作用。掌握它们的特性和关系,对于优化程序性能、灵活处理数据结构至关重要。
|
6月前
|
存储 NoSQL 编译器
C 语言中指针数组与数组指针的辨析与应用
在C语言中,指针数组和数组指针是两个容易混淆但用途不同的概念。指针数组是一个数组,其元素是指针类型;而数组指针是指向数组的指针。两者在声明、使用及内存布局上各有特点,正确理解它们有助于更高效地编程。
|
6月前
|
存储 C语言 计算机视觉
在C语言中指针数组和数组指针在动态内存分配中的应用
在C语言中,指针数组和数组指针均可用于动态内存分配。指针数组是数组的每个元素都是指针,可用于指向多个动态分配的内存块;数组指针则指向一个数组,可动态分配和管理大型数据结构。两者结合使用,灵活高效地管理内存。
|
6月前
|
容器
在使用指针数组进行动态内存分配时,如何避免内存泄漏
在使用指针数组进行动态内存分配时,避免内存泄漏的关键在于确保每个分配的内存块都能被正确释放。具体做法包括:1. 分配后立即检查是否成功;2. 使用完成后及时释放内存;3. 避免重复释放同一内存地址;4. 尽量使用智能指针或容器类管理内存。
|
6月前
|
存储 C语言
C语言如何使用结构体和指针来操作动态分配的内存
在C语言中,通过定义结构体并使用指向该结构体的指针,可以对动态分配的内存进行操作。首先利用 `malloc` 或 `calloc` 分配内存,然后通过指针访问和修改结构体成员,最后用 `free` 释放内存,实现资源的有效管理。
560 13
|
8月前
|
存储 人工智能 C语言
C语言程序设计核心详解 第八章 指针超详细讲解_指针变量_二维数组指针_指向字符串指针
本文详细讲解了C语言中的指针,包括指针变量的定义与引用、指向数组及字符串的指针变量等。首先介绍了指针变量的基本概念和定义格式,随后通过多个示例展示了如何使用指针变量来操作普通变量、数组和字符串。文章还深入探讨了指向函数的指针变量以及指针数组的概念,并解释了空指针的意义和使用场景。通过丰富的代码示例和图形化展示,帮助读者更好地理解和掌握C语言中的指针知识。
316 4
|
7月前
|
C语言
无头链表二级指针方式实现(C语言描述)
本文介绍了如何在C语言中使用二级指针实现无头链表,并提供了创建节点、插入、删除、查找、销毁链表等操作的函数实现,以及一个示例程序来演示这些操作。
90 0