- C编程教程
- C - 首页
- C语言基础
- C - 概述
- C - 特性
- C - 历史
- C - 环境设置
- C - 程序结构
- C - Hello World
- C - 编译过程
- C - 注释
- C - 词法单元
- C - 关键字
- C - 标识符
- C - 用户输入
- C - 基本语法
- C - 数据类型
- C - 变量
- C - 整数提升
- C - 类型转换
- C - 类型强制转换
- C - 布尔值
- C语言中的常量和字面量
- C - 常量
- C - 字面量
- C - 转义序列
- C - 格式说明符
- C语言中的运算符
- C - 运算符
- C - 算术运算符
- C - 关系运算符
- C - 逻辑运算符
- C - 位运算符
- C - 赋值运算符
- C - 一元运算符
- C - 自增和自减运算符
- C - 三元运算符
- C - sizeof 运算符
- C - 运算符优先级
- C - 其他运算符
- C语言中的决策
- C - 决策
- C - if 语句
- C - if...else 语句
- C - 嵌套if语句
- C - switch 语句
- C - 嵌套switch语句
- C语言中的循环
- C - 循环
- C - while 循环
- C - for 循环
- C - do...while 循环
- C - 嵌套循环
- C - 无限循环
- C - break 语句
- C - continue 语句
- C - goto 语句
- C语言中的函数
- C - 函数
- C - 主函数
- C - 按值调用函数
- C - 按引用调用函数
- C - 嵌套函数
- C - 可变参数函数
- C - 用户自定义函数
- C - 回调函数
- C - 返回语句
- C - 递归
- C语言中的作用域规则
- C - 作用域规则
- C - 静态变量
- C - 全局变量
- C语言中的数组
- C - 数组
- C - 数组的特性
- C - 多维数组
- C - 将数组传递给函数
- C - 从函数返回数组
- C - 可变长数组
- C语言中的指针
- C - 指针
- C - 指针和数组
- C - 指针的应用
- C - 指针运算
- C - 指针数组
- C - 指针到指针
- C - 将指针传递给函数
- C - 从函数返回指针
- C - 函数指针
- C - 指向数组的指针
- C - 指向结构体的指针
- C - 指针链
- C - 指针与数组
- C - 字符指针和函数
- C - 空指针
- C - void 指针
- C - 野指针
- C - 解引用指针
- C - 近指针、远指针和巨指针
- C - 指针数组的初始化
- C - 指针与多维数组
- C语言中的字符串
- C - 字符串
- C - 字符串数组
- C - 特殊字符
- C语言中的结构体和联合体
- C - 结构体
- C - 结构体和函数
- C - 结构体数组
- C - 自引用结构体
- C - 查找表
- C - 点(.)运算符
- C - 枚举(或枚举类型)
- C - 结构体填充和打包
- C - 嵌套结构体
- C - 匿名结构体和联合体
- C - 联合体
- C - 位域
- C - typedef
- C语言中的文件处理
- C - 输入和输出
- C - 文件I/O(文件处理)
- C预处理器
- C - 预处理器
- C - 编译指示
- C - 预处理器运算符
- C - 宏
- C - 头文件
- C语言中的内存管理
- C - 内存管理
- C - 内存地址
- C - 存储类
- 其他主题
- C - 错误处理
- C - 可变参数
- C - 命令执行
- C - 数学函数
- C - static 关键字
- C - 随机数生成
- C - 命令行参数
- C编程资源
- C - 问答
- C - 快速指南
- C - 速查表
- C - 有用资源
- C - 讨论
C语言中的查找表
C语言中的查找表(通常用缩写LUT表示)是填充了一些预先计算好的值的数组。查找表有助于避免在程序中执行大量计算。与冗长的嵌套if-else语句或switch语句相比,可以使用查找表来提高C程序的效率。
示例1
让我们看看查找表的一个简单应用。在下面的代码中,我们计算给定整数的平方。
#include <stdio.h>
int square(int x){
return x*x;
}
int main(){
int num[5] = {1, 2, 3, 4, 5};
for (int i = 0; i <= 4; i++){
printf("No: %d \tSquare(%d): %d\n", i+1, i+1, square(i+1));
}
return 0;
}
输出
运行此代码时,将产生以下输出:
No: 1 Square(1): 1 No: 2 Square(2): 4 No: 3 Square(3): 9 No: 4 Square(4): 16 No: 5 Square(5): 25
示例2
虽然上面的程序运行良好,但它涉及对每个数组索引值频繁调用square()函数。
相反,我们可以声明一个数组来存储数字的平方,并直接从索引访问计算出的平方。
#include <stdio.h>
int main(){
int squares[5] = {1, 4, 9, 16, 25};
for (int i = 0; i <= 4; i++){
printf("No: %d \tSquare(%d): %d\n", i+1, i+1, squares[i]);
}
return 0;
}
输出
运行代码并检查其输出:
No: 1 Square(1): 1 No: 2 Square(2): 4 No: 3 Square(3): 9 No: 4 Square(4): 16 No: 5 Square(5): 25
示例3
在下面的示例中,我们获取对应于原子序数的元素名称。
# include <stdio.h>
int main(){
int num = 3;
switch (num){
case 1: puts("Hydrogen"); break;
case 2: puts("Helium"); break;
case 3: puts("Lithium"); break;
case 4: puts("Beryllium"); break;
case 5: puts("Boron"); break;
default: puts("error: unknown element!");
}
return 0;
}
输出
它将产生以下输出:
Lithium
示例4
我们使用查找表(一个填充了所有元素名称的数组)来简化程序,而不是使用每个元素都有一个case的冗长的switch语句:
#include <stdio.h>
static const char *table[] = {
"Hydrogen", "Helium", "Lithium", "Beryllium", "Boron"
};
int main(){
int num = 3;
if (num >= 1 && num <= 5){
printf("Name of the element with atomic number %d is %s", num, table[num-1]);
} else {
puts("error: Atomic number not in the lookup table!");
}
return 0;
}
输出
运行代码并检查其输出:
Name of the element with atomic number 3 is Lithium
7段LED显示器中的查找表
查找表广泛用于嵌入式系统的设计中,因为它们可以提高应用程序的性能。
在许多设备中,7段LED显示器用于显示视觉输出。根据一系列二进制数字,该单元的八个段被点亮。我们使用查找表将0到9之间的数字转换为7段信号来驱动显示器。
示例
数字的7段二进制代码存储为数组元素。然后将十六进制代码转换为二进制代码,该代码将驱动7段显示器。
#include <stdio.h>
int main(){
// Array to represent numbers 0-9 in 7-segment display binary encoding
int const nums[] = {0x3f, 0x06, 0x5b, 0x4f, 0x66, 0x6d, 0x7d, 0x07, 0x7f, 0x6f};
static int bin[8];
int i = 0, num = 7, rem;
printf("The binary equivalent of 7 is: ");
for (i = 7; i >= 0; i--){
rem = num % 2;
bin[i] = rem;
num /= 2;
}
for (i = 0; i <= 7; i++){
printf("%d", bin[i]);
if (i == 3) printf(" ");
}
return 0;
}
输出
运行代码并检查其输出:
The binary equivalent of 7 is: 0000 0111
最低有效位表示段“a”、“b”、“c”和“d”。最高有效位是“e”、“f”、“g”和“h”。段“a”、“b”和“c”点亮以显示7,其他段保持关闭。
广告