【C语言】利用数组处理批量数据(字符数组)

简介: 【C语言】利用数组处理批量数据(字符数组)

前言:前面已经介绍了,字符数据是以字符的ASCII代码存储在存储单元中的,一般占一个字节。由于ASCII代码也属于整数形式,因此在C99标准中,把字符类型归纳为整型类型中的一种。


d6dc0126edd141a985d72de501ef756b.jpg

怎样定义字符数组

用来存放字符数据的数组是字符数组。在字符数组中的一个元素内存放一个字符。定义字符数组的方法与定义数值型数组的方法类似。例如:

char c[10];
c[0] ='I'; c[1] =' '; c[2] ='a'; c[3] ='m'; c[4] = ' '; 
c[5] = 'h'; c[6] ='a'; c[7] ='p'; c[8] = 'p'; c[9] = 'y';

由于字符型数据是以整数的形式(ASCII代码)存放的,因此也可以用整型数组来存放数据,例如:

int c[10];
c[0] = 'a';
//虽然合法,但是浪费空间

字符数组的初始化

对于字符数组的初始化,最容易理解的方式就是用"初始化列表",把各个字符赋给数组中的各个元素。例如:

char c[10] = {'I',' ','a','m',' ','h','a','p','p','y'};

把10个字符依次赋给c[0] ~c[9] 这10个元素。

如果在定义字符数组时不进行初始化,则数组中各元素的值是不可预料的。如果花括号中提供的初值的个数(即字符个数)大于数组长度,则出现语法错误。如果初值个数小于数组长度,则只将这些字符赋给数组中前面那些元素,其余的元素自动定为空字符(‘\0’),例如:

char c[10] = { 'a','b','c',' ','d','m','y','h' };

数组状态如下图所示:

(Vscode2019)下的状态

如果提供的初值个数与预定的数组长度相同,在定义时可以省略数组长度,系统会自动根据初值的个数确定数组长度。例如:

int main()
{
  char c[] = { 'a','b','c',' ','d','m','y','h' };
  printf("数组的长度是%d\n", sizeof(c)/sizeof(c[0]));//计算数组的长度
  return 0;
}

运行结果:


怎样引用字符数组中的元素

可以引用字符数组中的一个元素,得到一个字符。

例题:输出一个已知字符

int main()
{
  char c[15] = { 'I',' ','a','m',' ','a',' ','s','t','u','d','e','n','t'};
  int i = 0;
  for (i = 0; i < 15; i++)
  {
    printf("%c", c[i]);
  }
  printf("\n");
  return 0;
}

运行结果:


例题2:输出一个菱形

int main()
{
    int line = 0;
    scanf("%d", &line);
    //打印上半部分;
    int i = 0;
    for (i = 0; i < line; i++)
    {
        //打印一行
        //打印空格
        //打印*
        int j = 0;
        for (j = 0; j < line  - 1 - i ; j++)
        {
            printf(" ");
        }
        //打印*
        for (j = 0; j < 2 * i + 1 ; j++)
        {
            printf("*");
        }
        printf("\n");
    }
    //下
    for (i = 0; i < line - 1; i++)
    {
        //打印一行
        //打印空格
        //打印*
        int j = 0;
        for (j = 0; j <= i; j++)
        {
            printf(" ");
        }
        //打印*
        for (j = 0; j < 2 *(line - i - 1)- 1; j++)
        {
            printf("*");
        }
        printf("\n");
    }
    return 0;
}

运行结果:


字符串和字符串的结束标志

在C语言中,是将字符串作为字符数组来处理的。在实际工作中,人们关心的往往是字符串的有序长度。例如,定义一个字符数组的长度为100,而实际有效字符只有40个。为了测定字符串的实际长度,C语言规定了一个"字符串结束标志",以字符’\0’作为结束标志。如果字符数组中有若干字符前面9个字符都不是空字符(‘\0’),而第十个字符是‘\0’,则认为该数组中有一个字符串,其有效字符为9个。也就是说,遇到字符‘\0’ 时,表示字符串结束,把前面的字符组成一个字符串。

对于C语言处理字符串的方法有以上的了解后,再对字符数组初始化的方法补充了一种方法,即用字符串常量来使字符数组初始化。例如:

char c[] ="I am a student";

这里不像前面用单个字符作为字符数组的初始值,而是用一个字符串(注意字符串的两端是双撇号而不是单撇号扩起来的)作为初值。显然这种方式更加直观、方便、符号人们的习惯。请注意,此时c的长度不是14,而是15。因为字符串常量的最好由系统加上一个’\0’。

int main()
{
  char c[] = "I am a student";
  printf("sz = %d\n", sizeof(c) / sizeof(c[0]));//计算长度(包括\0)
  printf("len = %d\n", strlen(c));//计算长度(不包括\0)
  return 0;
}

运行结果:

(这里关于sizeof和strlen的区别就不具体说明,有感兴趣的可以看我之前文章,详细讲解了strlen与sizeof)关于strlen与sizeof


字符数组的输入输出

字符数组的输入输出可以有两种方法。

  1. 逐个字符输入输出。用格式符"%c"输入或输出一个字符如下图
  2. 将整个字符串一次输入或输出。用"%s"格式符,意思是对字符串(string)的输入输出。例如:
  char c[] = "china";
  printf("%s\n", c);

在内存中数组c的存储情况为:

输出时,遇到’\0’就停止输出。输出结果为:

用字符串处理函数

在C函数库中提供了一些专门处理字符串的函数,方便使用。几乎所有版本的C语言编译系统都提供这些函数。下面介绍几种常用的函数。

puts函数 – 输出字符串的函数

其一般形式为

puts(字符数组)

其作用是将一个字符串(以’\0’作为结束的字符序列)输出到终端,且puts函数输出使将字符串的结束标志’\0’转换成了’\n’,即输出完字符串后换行

例如:

int main()
{
  char c[] = "china";
  puts(c);
  return 0;
}

运行结果:


gets函数 – 输入字符串

其一般形式为:

gets(字符数组)

其作用是从终端输入一个字符串到字符数组,并得到一个函数值。该函数值是字符数组的起始地址。

例如:

int main()
{
  char c[10] = { 0 };
  gets(c);
  puts(c);
  return 0;
}

运行结果:


  • strcat函数 – 字符串连接函数
  • strcpy函数与strncpy函数 – 字符串复制函数
  • strcmp函数 – 字符串比较函数

关于这些函数的讲解在这里我也不过多介绍了,各位可以点这个连接跳转到我前面的博客,里面详细讲解了这几个函数并且如何模拟实现这些函数。

字符串函数的讲解与模拟实现


字符数组应用举例

例题:输入一行字符,统计其中有多少单词,单词之间用空格隔开。

方法1:

int main()
{
  char arr[20] = { 0 };
  gets(arr);
  char* str = arr;
  int count = 0;
  int i = 0;
  while (*str)//判断'\0'
  {
    if (*str != ' ')//找出非空格的数
    {
      count++;
    }
    str++;
  }
  printf("%d\n", count);
  return 0;
}

方法2:

int main()
{
  char arr[20] = { 0 };
  int i = 0;
  int count = 0;
  gets(arr);
  for (i = 0; i < 20; i++)//变量数组
  {
    if (arr[i] != '\0' && arr[i] != ' ')
    {
      count++;
    }
  }
  printf("%d\n", count);
  return 0;
}

运行结果:


结语:今天的内容就到这里吧,谢谢各位的观看,如果有讲的不好的地方也请各位多多指出,作者每一条评论都会读的,谢谢各位。


相关文章
|
8天前
|
存储 编译器 C语言
【C语言基础考研向】09 一维数组
数组是一种有序集合,用于存储相同类型的数据,便于统一操作与管理。例如,将衣柜底层划分为10个格子存放鞋子,便于快速定位。在C语言中,数组定义格式为 `类型说明符数组名[常量表达式];`,如 `int a[10];` 表示定义了一个包含10个整数的数组。数组初始化时可以直接赋值,也可以部分赋值,且数组长度必须固定。数组在内存中连续存储,访问时需注意下标范围,避免越界导致数据异常。数组作为参数传递时,传递的是首地址,修改会影响原数组。
|
8天前
|
存储 C语言
【C语言基础考研向】10 字符数组初始化及传递和scanf 读取字符串
本文介绍了C语言中字符数组的初始化方法及其在函数间传递的注意事项。字符数组初始化有两种方式:逐个字符赋值或整体初始化字符串。实际工作中常用后者,如`char c[10]=&quot;hello&quot;`。示例代码展示了如何初始化及传递字符数组,并解释了为何未正确添加结束符`\0`会导致乱码。此外,还讨论了`scanf`函数读取字符串时忽略空格和回车的特点。
|
11天前
|
存储 人工智能 C语言
C语言程序设计核心详解 第六章 数组_一维数组_二维数组_字符数组详解
本章介绍了C语言中的数组概念及应用。数组是一种存储同一类型数据的线性结构,通过下标访问元素。一维数组定义需指定长度,如`int a[10]`,并遵循命名规则。数组元素初始化可使用 `{}`,多余初值补0,少则随机。二维数组扩展了维度,定义形式为`int a[3][4]`,按行优先顺序存储。字符数组用于存储字符串,初始化时需添加结束符`\0`。此外,介绍了字符串处理函数,如`strcat()`、`strcpy()`、`strcmp()` 和 `strlen()`,用于拼接、复制、比较和计算字符串长度。
|
11天前
|
C语言
C语言程序设计核心详解 第二章:数据与数据类型 4种常量详解 常见表达式详解
本文详细介绍了C语言中的数据与数据类型,包括常量、变量、表达式和函数等内容。常量分为整型、实型、字符型和字符串常量,其中整型常量有十进制、八进制和十六进制三种形式;实型常量包括小数和指数形式;字符型常量涵盖常规字符、转义字符及八进制、十六进制形式;字符串常量由双引号括起。变量遵循先定义后使用的规则,并需遵守命名规范。函数分为标准函数和自定义函数,如`sqrt()`和`abs()`。表达式涉及算术、赋值、自增自减和逗号运算符等,需注意运算符的优先级和结合性。文章还介绍了强制类型转换及隐式转换的概念。
|
29天前
|
存储 编译器 数据处理
【编程秘籍】解锁C语言数组的奥秘:从零开始,深入浅出,带你领略数组的魅力与实战技巧!
【8月更文挑战第22天】数组是C语言中存储同类型元素的基本结构。本文从定义出发,详述数组声明、初始化与访问。示例展示如何声明如`int numbers[5];`的数组,并通过下标访问元素。初始化可在声明时进行,如`int numbers[] = {1,2,3,4,5};`,编译器自动计算大小。初始化时未指定的元素默认为0。通过循环可遍历数组,数组名视为指向首元素的指针,方便传递给函数。多维数组表示矩阵,如`int matrix[3][4];`。动态数组利用`malloc()`分配内存,需用`free()`释放以避免内存泄漏。掌握这些技巧是高效数据处理的基础。
50 2
|
30天前
|
C语言
【C语言】在限制定条件下数据移动
【C语言】在限制定条件下数据移动
26 1
|
28天前
|
存储 算法 搜索推荐
C语言中数组
C语言中数组
32 0
|
1月前
|
C语言
【C语言篇】字符和字符串以及内存函数详细介绍与模拟实现(下篇)
perror函数打印完参数部分的字符串后,再打印⼀个冒号和⼀个空格,再打印错误信息。
|
1月前
|
存储 安全 编译器
【C语言篇】字符和字符串以及内存函数的详细介绍与模拟实现(上篇)
当然可以用scanf和printf输入输出,这里在之前【C语言篇】scanf和printf万字超详细介绍(基本加拓展用法)已经讲过了,这里就不再赘述,主要介绍只针对字符的函数.