zoukankan      html  css  js  c++  java
  • 一些itoa()函数

    以下资料来自:http://www.ok2002.com/cc/cc/s.asp?r=a2273562157719

    __rev()函数有一处错误,特复制过来进行更改:

    //C++ itoa原型,itoa函数原型,转换正数为字符串,转换负数为字符串
    /*--------- 1.转换正数为字符串 (1)用模运算的方法取得最后一位数,将这位数字转换为字符. (2)接着用整除的方法删除这位数字. 再取剩下数字的最后一位,转为字符,删除, 就这样直到将全部数字转为字符. (3)将'\0'之前的所有字符倒置即得到所要的字符串. 2.转换负数为字符串 (1)负数转换为正数处理. (2)处理完后,在'\0'之前添加字符'-'. (3)并将'\0'之前的全部字符倒置. ----------*/ #include<iostream> using namespace std; //反转字符串的指针版本 void __rev(char *s)//原函数 只有一位数的时候出错,如1 { char *p=s; char *q=s; char temp; while('\0'!=*(++q+1)); // cout<<*q<<endl; while(p<q) { if(*p!=*q) { temp=*p; *p=*q; *q=temp; } ++p; --q; } }
    void __rev(char *s)//修改后的函数
    {
    	char *p=s;
    	char *q=s;
    	char temp;
    	while('\0'!=*q)
    {
          ++q;
        };     --q; while(p<q) { if(*p!=*q) { temp=*p; *p=*q; *q=temp; } ++p; --q; } }
    void itoa(int n,char *s)
    {
    	int sign=n;
    	if(sign<0)
    		n=-n;
    	int i=0;
    	do
    	{
    		s[i++]=n%10+'0';//取最后一位数转换
    
    		n=n/10;//删除最后一位
    
    	}while(n>0);
    
    	if(sign<0)
    		s[i++]='-';
    	s[i]='\0';
    	__rev(s);
    }
    
    void main()
    {
    	int a=-12345;
    	char b[20];
    	itoa(a,b);
    	cout<<b<<endl;
    }
    
    /*--
    -12345
    Press any key to continue
    --*/



    另外还有能够选择进制的版本:

    char *myitoa(int num,char*str,int radix)

    {

        char index[]="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";

        unsigned unum;

        int i=0,j,k;

        if(radix==10 && num<0)

        {

            unum=(unsigned)-num;

            str[i++]='-';

        }

        else

            unum=(unsigned)num;

        do

        {

            str[i++]=index[unum%(unsigned)radix];

            unum/=radix;

        }while(unum);

        str[i]='\0';

        if(str[0]=='-')k=1;

        else k=0;

        for(j=k;j<(i-1)/2.0+k;j++)

        {

            num=str[j];

            str[j]=str[i-j-1+k];

            str[i-j-1+k]=num;

        }//此处比较晦涩难懂

        return str;

    }

     
  • 相关阅读:
    饿了么 PostgreSQL 优化之旅
    kubernetes 滚动更新发布及回滚
    kubernetes yaml
    mongodb安装
    node.js安装
    linux输出换行
    把token放入请求头
    $.ajaxSetup
    js前端读取文件内容
    v-echarts安装
  • 原文地址:https://www.cnblogs.com/qmlm8844/p/2780461.html
Copyright © 2011-2022 走看看