统计字符串中元素的个数(多种方法)

简介: 统计字符串中元素的个数(多种方法)

统计字符串中元素的个数(多种方法)

对于字符串,我想大家并不陌生,一个充满了玄幻的代名词,对于笔者这样的小白而言:字符串代表了不仅仅是难度,更是充满着些许煎熬!在刚开始接触字符串时候,感觉确实挺难的,但是经过长期的对变态试题的打击,这种感觉却是少了不少!只要读者静下心来认认真真的分析,一定能够达到不错的高度!至少对于字符串没啥问题!相信自己,我能行,加油干就是了!


话不多说,下面请跟随笔者进入本片博文的主题!统计字符串中元素的个数(多种方法)!!


1。库函数strlen()的使用,对于库函数strlen()我们需要知道:


       的用法为:    strlen(数组名);但是对于库函数strlen()不统计字符串结尾的标志'\0';


下面请看笔者代码!


//用库函数strlen()来求字符串长度
#include <stdio.h>
#include <string.h>
int main()
{
  char arr[] = "abcdef";
  int len = strlen(arr);           //库函数strlen()来实现求字符串长度
  printf("%d\n", len);
  return 0;
}

对于此代码,并没有过多的需要讲解的部分,只要知道库函数strlen()的用法,及需要头文件#include <string.h>的使用就可以了,因此,在这里笔者就不做过多的讲述!


最后的打印结果为:


0a2653c851af460fa595bd959398a8f1.png


2。模拟库函数strlen()的用法,来创建一个函数,来统计字符串长度的计数器


相比较单一的使用main函数而言,创建函数是一个简单而又清晰易懂的写法,能够使得代码显得更加完整无缺!


下面请跟着笔者思路来创建一个函数实现strlen()的功能,作为一个计数器,来统计字符串中的长度!


笔者所书写的代码如下所示:


//写一个函数,模拟实现库函数strlen()的功能
//来对字符串中的数字进行统计其长度
#include <stdio.h>
int my_strlen(char* str)
{
  int count = 0;
  while (*str != '\0')
  {
  count++;
  str++;
  }
  return count;
}
int main()
{
  char arr[] = "abcdefgh";
  int len = my_strlen(arr);
  printf("%d\n", len);
  return 0;
}


上述代码中,将字符串以数组的形式char arr[] = "abcdefgh";定义,通过函数my_strlen(arr),进行传递,然后在形参中,通过指针来接收,对于实参传递给形参的是首元素的地址,因此需要用指针来接收地址!而且又需要返回值,所以定义为:   int my_strlen(char* str)    


对于下述形参中的代码:


int my_strlen(char* str)
{
  int count = 0;
  while (*str != '\0')
  {
  count++;
  str++;
  }
  return count;
}

在其中,count充当计数器的作用,在while()循环体中,一直遇到'\0'停止,(在这里'\0'相当于键盘敲击回车键),然后返回count的数值给len,最后在打印出来,因此函数my_strlen()成功的替代了对库函数strlen()的使用!


该段代码的运算结果为:


6de278e6d6694ce5bb08e7e842b7e74b.png


上述代码虽然实现了用my_strlen来代替库函数实现求字符串长度,但是,看着代码感觉有着些许难度,因此还能用递归的求法,来实现求字符串的长度!


3.下面是笔者用递归的解答方法,来实现求字符串的长度!


对于递归,刚开始学习时候也是有点懵逼,但是等着慢慢接触,熟悉递归了以后,感觉递归好简单,最后到了,不管题目什么要求,直接往递归上面想,殊不知.........


下面请看笔者所写代码,仅供参考!


//通过递归的方法:模拟实现库函数strlen()的功能
//来对字符串中的数字进行统计其长度
#include <stdio.h>
int my_strlen(char* str)
{
  if (*str == '\0')
  return 0;
  else
  return my_strlen(str + 1) + 1;
  //这种方法不使用任何变量和库函数,到结尾\0才结束
}
int main()
{
  char arr[] = "abcdefghi";
  int len = my_strlen(arr);
  printf("%d\n", len);
  return 0;
}


在这面仍然使用了指针的方法来求字符串的长度!


并且多次调用:


int my_strlen(char* str)
{
  if (*str == '\0')
  return 0;
  else
  return my_strlen(str + 1) + 1;
  //这种方法不使用任何变量和库函数,到结尾\0才结束
}

在这里面: else     my_strlen(str + 1) + 1;意思就是判断读取的函数不是'\0'则进行+1;然后在通过 my_strlen(str + 1)对下一位字符进行读取判断,一直到遇见'\0'时为止!

   因此:这种方法不使用任何变量和库函数,到结尾\0才结束


12c3b7f3f8814309a195c64f051d4445.png


本文到此就结束了,读者若有其他不同的想法,请联系笔者进行有效增添!


相关文章
|
1月前
|
机器学习/深度学习 算法 数据处理
盘点四种计算数组中元素值为1的个数的方法
盘点四种计算数组中元素值为1的个数的方法
24 0
|
11月前
定义一个包含10个整数元素的数组,初始值由用户给定。找出数组中的最大数并连同下标一起输出。
定义一个包含10个整数元素的数组,初始值由用户给定。找出数组中的最大数并连同下标一起输出。
165 0
|
Serverless C++
C/C++编程题之字符个数统计
C/C++编程题之字符个数统计
|
移动开发 网络协议 测试技术
统计不同类型的字符个数 | 学习笔记
快速学习统计不同类型的字符个数
101 0
统计不同类型的字符个数 | 学习笔记
|
Java
Java 题目1:定义一个包含10个元素的数组,对其进行赋值,使每个元素的值等于其下标,然后输出;最后将这个数组倒置(即首尾交换)后输出。
题目:定义一个包含10个元素的数组,对其进行赋值,使每个元素的值等于其下标,然后输出;最后将这个数组倒置(即首尾交换)后输出。
303 0
|
缓存 C语言
练习12—统计特定字符个数
练习12—统计特定字符个数
随机生成一个short型一维数组,从控制台输入一个数值,遍历数组查找,如果找到了,打印出该数在数组中的位置,如果没有查到,请将该数值插入并形成新的数组(要求降序)
随机生成一个short型一维数组,从控制台输入一个数值,遍历数组查找,如果找到了,打印出该数在数组中的位置,如果没有查到,请将该数值插入并形成新的数组(要求降序)
129 0
|
C语言 UED
[解题报告]【第29题】给定一个 n 个元素的数组, 删除数组第一个位置上的数,然后再输出整个数组
[解题报告]【第29题】给定一个 n 个元素的数组, 删除数组第一个位置上的数,然后再输出整个数组