【1】main.c


/****************************************************
*
* 把整数按照进制数转换为相应进制的字符串
*(要考虑符号),比如 -1234,转换为 “-1234”。
*
*
****************************************************/ #include <stdio.h>
#include <string.h> #define BUF_LEN 12 //将数字转换成十进制子函数
void iToDecCh(int iNum,char *p); //字符串倒置函数
void strReverse(char* str); /*
根据不同的进制申请不同的字符空间
因为有符号的int最大值为:
INT_MAX: +2147 4836 47
INT_MIN: -2147 4836 47
共需要11个字符,加上最后的'\0';则需要12字节的空间 任何1个整数表示成16进制,则需要 0X FFFF FFFF
2+8 个字符,加上最后的'\0';则需要11个字节的空间 这里定义12个字符的buf。
*/
char strBuf[BUF_LEN]; /*******
*
* 主函数: main 函数开始
*
********/
int main()
{
char* p; iToDecCh(,strBuf);
//strReverse(strBuf); p=strBuf;
while(*p)
putchar(*p++); getchar();
return ;
} /******************************************
将一个数字转换成十进制字符串
算法: 原型:
void iToDecCh(int num,char *p)
返回值:

参数:
int num: 待转换的数字
char* p: 存储字符串的线性地址空间首地址
异常:

其他:

********************************************/
void iToDecCh(int num,char *p)
{
int i;
int flag; unsigned int decMask;
unsigned int signedFlag; signedFlag=0x8000000; // 用于判断正负 if(==num)
{
p[]='+';
p[]='';
return ;
} //判断正、负情况
if(num & signedFlag)
{
flag=; // p[11] ='-'; 负数
num=- * num; //将负数变成整数
}
else
{
flag=; // p[11] ='+'; 正数
} i=;
while(num > )
{
p[i++]= num % + '';
num=num /;
} if(flag==)
p[i++]='+';
else
p[i++]='-'; p[i]='\0'; strReverse(p);
} /*****************************************
字符串倒置函数
算法: 原型:
void strReverse(char* str)
返回值:

参数:
char *str:待倒置的字符串首地址
异常:

其他: ******************************************/
void strReverse(char* str)
{
int i,
j; j=strlen(str); for(i=,j--;i<j;i++,j--)
{
str[i]=str[i] ^ str[j];
str[j]=str[j] ^ str[i];
str[i]=str[j] ^ str[i];
}
}


【2】main.c

#include <stdio.h>
#include <string.h> #define NUL ('\0') char ftoaArray[];
char itoaArray[]; //字符串倒置函数,将 “abcd” 倒置为 “dcba”
char* strRev(char* str)
{
char* head;
char* pShift; head=str;
pShift=str; while(*pShift) pShift++; --pShift;
while(pShift>head)
{
*pShift = *pShift ^ *head;
*head = *pShift ^ *head;
*pShift-- = *pShift ^ *head++; //最后的时候移动指针的指向
} return str;
} //将浮点数转换为字符串, 保留4位数据精度
//这里是在ADC转换的时候,进行测试用的
//所以这里没有进行正负的判断
char* ftoa(float num)
{
int i;
int x;
float y;
char* shift; x=(int)num; //取数据的整数部分 shift=ftoaArray;
while(x > )
{
*shift++= x% + '';
x /= ;
}
*shift++ = x + '';
*shift = NUL ;
strRev(ftoaArray); *shift++ = '.'; //把最后的 '\0' 替换为 '.' //这样处理就可以将小数点小于4位、和大于4位的都处理完
i=;
y=num-(int)num; //y为小于1的小数
while(y>0.000001)
{
y= y*;
x=y;
*shift++ =x +'';
y = y-(int)(y); if(==i) //不管有没有转换完,循环4次都跳出
{
break;
}
i++;
}
*shift = NUL; return ftoaArray;
} //将十进制的数转换为字符串
char* itoa(unsigned short num)
{
int i=; while(num >= )
{
itoaArray[i++]=num% + '';
num /= ;
}
itoaArray[i++]=num + '';
itoaArray[i]=NUL; strRev(itoaArray); return itoaArray;
} /*******
*
* 主函数: main 函数开始
*
********/
int main()
{ char* str="abcd";
strRev(str);
puts(str); itoa();
puts(itoaArray); ftoa(311.1415516);
printf("%s",ftoaArray); getchar();
return ;
}

其实,在第二个的itoa中,可以用指针代替数组的index索引,用指针速度更快。

【算法和数据结构】_11_小算法_itoa、ftoa及字符串倒置的更多相关文章

  1. python算法与数据结构-选择排序算法(33)

    一.选择排序的介绍 选择排序(Selection sort)是一种简单直观的排序算法.首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素, ...

  2. python算法与数据结构-希尔排序算法(35)

    一.希尔排序的介绍 希尔排序(Shell Sort)是插入排序的一种.也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本.希尔排序是非稳定排序算法. 希尔排序是把记录按下标的一定增量分组,对每 ...

  3. python算法与数据结构-算法介绍(31)

    一.算法和数据结构 什么是算法和数据结构?如果将最终写好运行的程序比作战场,我们程序员便是指挥作战的将军,而我们所写的代码便是士兵和武器. 那么数据结构和算法是什么?答曰:兵法!故,数据结构和算法是一 ...

  4. 数据结构(DataStructure)与算法(Algorithm)、STL应用

    catalogue . 引论 . 数据结构的概念 . 逻辑结构实例 2.1 堆栈 2.2 队列 2.3 树形结构 二叉树 . 物理结构实例 3.1 链表 单向线性链表 单向循环链表 双向线性链表 双向 ...

  5. 浅谈算法和数据结构: 七 二叉查找树 八 平衡查找树之2-3树 九 平衡查找树之红黑树 十 平衡查找树之B树

    http://www.cnblogs.com/yangecnu/p/Introduce-Binary-Search-Tree.html 前文介绍了符号表的两种实现,无序链表和有序数组,无序链表在插入的 ...

  6. Python算法与数据结构--求所有子数组的和的最大值

    Python算法与数据结构--求所有子数组的和的最大值 玄魂工作室-玄魂 玄魂工作室秘书 玄魂工作室 昨天 题目:输入一个整形数组,数组里有正数也有负数.数组中连续的一个或多个整数组成一个子数组,每个 ...

  7. 【数据结构】KMP算法

    我还是不太懂... 转2篇大神的解释    1>https://www.cnblogs.com/yjiyjige/p/3263858.html     2>https://blog.csd ...

  8. [Oracle] 关系型数据库排序算法和数据结构以及关联查询

    关系型数据库排序算法和数据结构以及关联查询 1. Merge sort 理解merge sort算法将有助于更好地理解数据库join操作 - merge join 算法逻辑 将2个有序的大小为N/2的 ...

  9. 数据结构与算法系列----最小生成树(Prim算法&amp;Kruskal算法)

     一:Prim算法       1.概览 普里姆算法(Prim算法).图论中的一种算法.可在加权连通图里搜索最小生成树.意即由此算法搜索到的边子集所构成的树中.不但包含了连通图里的全部顶点(英语:Ve ...

随机推荐

  1. 知方可补不足~row_number,rank,dense_rank,ntile排名函数的用法

    回到目录 这篇文章介绍SQL中4个很有意思的函数,我称它的行标函数,它们是row_number,rank,dense_rank和ntile,下面分别进行介绍. 一 row_number:它为数据表加一 ...

  2. 前端那点事儿——Tocify自动生成文档目录

    今天偶然间看到文档服务器有一个动态目录功能,点击目录能跳转到指定的位置:窗口滑动也能自动更新目录的焦点. 效果 框架 原来使用的是一个开源的jquery-ui控件——tocify.js,它可以遍历页面 ...

  3. [Java面试三]JavaWeb基础知识总结.

    1.web服务器与HTTP协议 Web服务器 l WEB,在英语中web即表示网页的意思,它用于表示Internet主机上供外界访问的资源. l Internet上供外界访问的Web资源分为: • 静 ...

  4. Atian inputmethod 输入法解决方案 方言与多语言多文字支持 英语汉字汉语阿拉伯文的支持 (au

    Atian inputmethod 输入法解决方案 方言与多语言多文字支持 英语汉字汉语阿拉伯文的支持 (au 1.1. Overview概论 支持母语优先的战略性产品,主要是针对不想以及不愿使用普通 ...

  5. 开始使用MarkDown写博客

    MarkDown 标题 #h1 ##h2 ###h3 h1 h2 h3 代码段 代码段缩进4个空格即可,如下: <div class="form-group"> < ...

  6. HashSet源码详解

    序言 在写了HashMap文章后,隔了几天才继续这一系列的文章,因为要学的东西实在是太多了,写一篇要花费的时间很多,所以导致隔了几天才来写.不过希望自己坚持下去.终有一天会拨开云雾见青天的.学Hash ...

  7. 基于Metronic的Bootstrap开发框架经验总结(9)--实现Web页面内容的打印预览和保存操作

    在前面介绍了很多篇相关的<Bootstrap开发框架>的系列文章,这些内容基本上覆盖到了我这个Bootstrap框架的各个主要方面的内容,总体来说基本达到了一个稳定的状态,随着时间的推移可 ...

  8. Cocos2d-x 3.2 学习笔记(四)学习打包Android平台APK!

    从cocos2dx 3.2项目打包成apk安卓应用文件,搭建安卓环境的步骤有点繁琐,但搭建一次之后,以后就会非常快捷! (涉及到3.1.1版本的,请自动对应3.2版本,3.x版本的环境搭建都是一样的) ...

  9. Spring学习总结(三)——Spring实现AOP的多种方式

    AOP(Aspect Oriented Programming)面向切面编程,通过预编译方式和运行期动态代理实现程序功能的横向多模块统一控制的一种技术.AOP是OOP的补充,是Spring框架中的一个 ...

  10. 学习使用 CSS3 制作网站面包屑导航效果

    作为最重要的导航展示形式之一,面包屑导航能够让用户更清楚的知道他们所在页面的层次结构,让他们可以方便的导航到上一层页面.在本教程中,您将学习如何使用 CSS3 技术创建自己的面包屑导航效果. 效果演示 ...