专栏首页EdisonTalk你必须知道的指针基础-5.指针的几个小应用案例

你必须知道的指针基础-5.指针的几个小应用案例

一、使用指针传出分解后的数字

  实现一个方法“多个返回值”的效果:返回一个三位数数字的个位、十位、百位。这里,我们借助指针来”返回“分解后的结果。这种应用也是最常见的指针应用。

// fun1:分解一个三位数,传递个位、十位和百位数字
int parseNumber(int num,int* g,int* s,int* b)
{
    if(num < 100 || num > 999)
    {
        // 只允许100~999的数字
        return -1;
    }

    *g = num % 10;
    *s = (num / 10)%10;
    *b = (num/100)%10;

    return 1;
}

  测试数字为365,调用parseNumber函数,将要返回的值的地址作为参数传递:

int main(int argc, char *argv[])
{
    int num = 365;
    int g,s,b;
    if(parseNumber(num,&g,&s,&b))
    {
        printf("%d %d %d\n",b,s,g);
    }
    return 0;            
}

  运行结果如下图所示:

二、自己动手实现strlen()函数

  我们知道strlen是计算字符串的长度,其内部是通过判断是否以'\0'作为结束符,虽然其不是一个安全的方式,但是却是各大C教材中最常见的函数。这里,我们来自己实现一个strlen函数,利用指针的移动来辅助计算长度,这也是指针的一个最常见的应用。

// fun2:自己模拟实现strlen函数
int myStrlen(char* str)
{
    int len = 0;
    while(*str != '\0')
    {
        str++;
        len++;
    }

    return len;
}

  测试字符串为”hello“,长度为5,Main函数声明如下:

int main(int argc, char *argv[])
{
    char test[] = "hello";
    int len = myStrlen(test);
    printf("The length of 'hello' is %d\n",len);
    return 0;
}

  运行结果如下图所示:

三、判断字符串A是否以字符串B结尾

  判断一个字符串是否以另一个子子字符串结尾,这个方法在Java中属于String类,叫做endsWith。在C#中,也位于String类,叫做EndsWith,并提供了三个重载。这里,我们借助指针来辅助实现这个经典的endsWith方法。

// fun3:判断字符串A是否以字符串B结尾
int endsWith(char* str,char* substr)
{
    int strlen = 0;
    while(*str != '\0')
    {
        str++;
        strlen++;
    }

    int sublen = 0;
    while(*substr != '\0')
    {
        substr++;
        sublen++;
    }

    if(strlen < sublen)
    {
        // 如果子串长度比主串还长
        return -1;
    }

    int i;
    for(i=0;i<=sublen;i++)
    {
        // 从末尾开始对比每一个字符
        char strCh = *str;
        char subCh = *substr;
        if(strCh != subCh)
        {
            return 0;
        }
        else
        {
            str--;
            substr--;
        }
    }

    return 1;
}

  该方法主要经历两个步骤,一是分别计算主串和子串的长度,如果子串长度超过主串长度,那么直接返回0,代表主串不以子串结尾;二是分别从末尾对主串和子串的每一个字符进行比对,直到循环结束(判断条件是子串的长度),如果其中有一个不同,那么直接返回0。

  下面对这个endsWith函数进行一个简单的测试,分别给出一个合适的用例和不合适的用例:、

int main(int argc, char *argv[])
{
    char str[] = "edisonchou";
    char sub[] = "chou";
    printf("%d\n", endsWith(str,sub));
    char sub2[] = "zhou";
    printf("%d\n", endsWith(str,sub2));
    
    return 0;
}

  运行结果如下图所示:

参考资料

  如鹏网,《C语言也能干大事(第三版)》

作者:周旭龙

出处:http://edisonchou.cnblogs.com

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 你必须知道的指针基础-7.void指针与函数指针

      void *表示一个“不知道类型”的指针,也就不知道从这个指针地址开始多少字节为一个数据。和用int表示指针异曲同工,只是更明确是“指针”。

    Edison Zhou
  • 《你必须知道的.NET》读书实践:一个基于OO的万能加载器的实现

    此篇已收录至《你必须知道的.Net》读书笔记目录贴,点击访问该目录可以获取更多内容。

    Edison Zhou
  • 初探机器学习之推荐系统的基础知识

     最近公司有意做一款机器学习的应用,主要集中于推荐系统这个方向,因此看了看一些基础知识,此篇是一个学习总结,不算是完整原创文章。

    Edison Zhou
  • 团体程序设计天梯赛-练习集 L1-016 查验身份证

    一个合法的身份证号码由17位地区、日期编号和顺序编号加1位校验码组成。校验码的计算规则如下:

    C you again 的博客
  • C/C++练习题(一)

    (分析:第一个坑:运算符优先级,+的优先级大于>>;第二个坑:当小类型变量和整型做运算的时候,会转化为int类型。

    Daotin
  • 【LeetCode第 177 场周赛】5169. 日期之间隔几天

    输入:date1 = "2019-06-29", date2 = "2019-06-30" 输出:1 示例 2:

    韩旭051
  • Android程序员经常遇到的算法问题,七大常用的算法

    插入排序的基本思想是在遍历数组的过程中,假设在序号 i 之前的元素即 [0..i-1] 都已经排好序,本趟需要找到 i 对应的元素 x 的正确位置 k ,并且在...

    Android技术干货分享
  • 网易2013校园招聘笔试题详解

    http://blog.csdn.net/silangquan/article/details/18142651

    bear_fish
  • hdu1055

    @坤的
  • LeetCode 7. 整数反转

    假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为 [−231, 231 − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。

    freesan44

扫码关注云+社区

领取腾讯云代金券