zoukankan      html  css  js  c++  java
  • C语言编程 递归方法与非递归方法 实现将参数字符串中的字符反向排列

    //题目要求要求:不能使用C函数库中的字符串操作函数
    (否则本题也没什么意义了啊)

    <1>非递归方法
    此方法基本思想是设立两个指针,分别指向字符串的头尾
    并且依次交换所指向的数据,代码中为left和right
    源代码:

    #include<stdio.h>
    #include<stdlib.h>
    #include<string.h>//因为要使用strlen()语句
    void reverse_string(char str[])
    {
        int temp;
        char *left = str;
        char *right = str + strlen(str) - 1;
        while (*left <* right)
        {
            temp = *left;
            *left = *right;
            *right = temp;
            *right--;
            *left++;
        }
    }
    int main()
    {
        char str[] = "chooseyou";
        printf("%s
    ", str);
        reverse_string(str);
        printf("%s", str);
        system("pause");
        return 0;
    }

    <2>递归方法
    递归方法思想如下图
    类似于非递归的left与right指针所指数据互换
    递归时只订立一个指针,每一次通过未交换字符串的长度(len)来表示所指向的元素的字符串倒数除外第一个元素。

    每一次的递归将指针所指的元素储存进一个变量,并且将倒数第一个元素(除外),与所知元素换再把最后元素置为,然后改变len进行下次递归。

    最后的效果是字符串由长变短再变长得以完成反向排列
    详解如图

    C语言编程  递归方法与非递归方法 实现将参数字符串中的字符反向排列
    C语言编程  递归方法与非递归方法 实现将参数字符串中的字符反向排列

    源代码:

    #include<stdio.h>
    #include<stdlib.h>
    void reverse_string(char *str)
    {
        int len = strlen(str);
        char temp=*str;//当前所指元素
        *str = *(str + len - 1);//除外最后一个元素
        *(str + len - 1) = '';//置
        if (strlen(str + 1) >= 2)//长度小于等于1则不需要交换
        {
            reverse_string(str + 1);
        }
        *(str + len - 1) = temp;//将储存的元素反序序放回字符串完成反向排序
    }
    int main()
    {
        char str[] = "chooseyou";
        printf("%s
    ", str);
        reverse_string(str);
        printf("%s
    ", str);
        system("pause");
        return 0;
    }

    注意:要修改的字符串要以数组类型存储(str[]),*str储存为只读类型,强行写值会出错

  • 相关阅读:
    JAVA学习笔记 -- 包资源文件jar包裹
    Hibernate一个简短的引论
    JMS分布式应用程序异步消息解决方案EhCache 高速缓存同步问题
    一个红
    Android技术——切换视图(两)随着ViewPage达到Tab幻灯片浏览
    hdu 2243 考研绝望——复杂的文字(AC自己主动机+矩阵高速功率)
    我在这里3在引发众1.8万的经验分享
    关系数据库的基本概念和MySQL说明
    2015第5周日
    HTML5
  • 原文地址:https://www.cnblogs.com/Kaniso-Vok/p/13756262.html
Copyright © 2011-2022 走看看