• c语言练习题55:IP 地址⽆效化


    IP 地址⽆效化

    题⽬描述: 给你⼀个有效的 IPv4 地址 address ,返回这个 IP 地址的⽆效化版本。 所谓⽆效化 IP 地址,其实就是⽤ "[.]" 代替了每个 "."。

    • ⽰例 1: 输⼊:address = "1.1.1.1" 输出:"1[.]1[.]1[.]1"

    • ⽰例 2: 输⼊:address = "255.100.50.0" 输出:"255[.]100[.]50[.]0"

    • 提⽰: 给出的 address 是⼀个有效的 IPv4 地址

    算法思路:

    1. 定义⼀个空字符串 ans ,并将其初始化为空;

    2. 遍历原字符串,当遇到‘.’时,将'[','.',']'依次添加进新字符串;

    3. 否则将遍历到的字符直接添加进字符串 ans 。 • 这⾥需要定义另外的指针指向新字符串第⼀位作为返回值,并且要在新字符串最后⼀位添 加'\0',否则可能会导致以下问题:

    1. 访问越界:如果程序试图读取没有以空字符结尾的字符串的内容,它可能会读取字符串后⾯的内 存区域,这可能会导致程序访问超出其允许范围的内存,从⽽导致崩溃或其他错误。

    2. 错误输出:如果程序试图将没有以空字符结尾的字符串输出到标准输出(如屏幕或⽂件),它可 能会输出字符串后⾯的内存区域,这可能会导致输出错误的结果。

    1. //IP 地址⽆效化
    2. char* defangIPaddr(char* address) {
    3. int len = strlen(address);
    4. char* ptr = NULL;
    5. //定义指针指向字符串⾸位,并且为新字符串分配内存
    6. char* ans = ptr = malloc(len + 6 + 1);
    7. //利⽤指针遍历字符串,当前字符不为'\0'时进⼊循环
    8. while (*address)
    9. {
    10. //判断当前字符是否为'.',是则将"[.]"添加进新字符串
    11. if (*address = '.') {
    12. *ptr++ = '[';
    13. *ptr++ = '.';
    14. *ptr++ = ']';
    15. }
    16. else {
    17. *ptr++ = *address;
    18. }
    19. //将指针指向字符串下⼀位字符
    20. address++;
    21. }
    22. //将字符串最后⼀位赋值为'\0',防⽌访问越界或错误输出
    23. *ptr = '\0';
    24. //返回指向字符串⾸位的指针
    25. return ans;
    26. }

  • 相关阅读:
    C#设计模式---工厂方法模式
    《进化优化》第3章 遗传算法
    digitalLogic_逻辑门和基本公式
    Edge获取网页内置的pdf
    golang开发:go并发的建议(完)
    LIO-SAM 详读代码笔记--2.imuPreintegration
    20220920线程属性
    Postman:API测试之Postman使用完全指南
    基于CNN-BiLSTM与三支决策的入侵检测方法
    华为OD 打印任务排序(100分)【java】A卷+B卷
  • 原文地址:https://blog.csdn.net/2301_77479435/article/details/132859471