欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

深入C++實(shí)現(xiàn)函數(shù)itoa()的分析

 更新時(shí)間:2013年05月29日 11:43:33   作者:  
本篇文章是對(duì)C++實(shí)現(xiàn)函數(shù)itoa()進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
函數(shù)itoa()是將整數(shù)型轉(zhuǎn)換為c語(yǔ)言風(fēng)格字符串的函數(shù),原型:
char * itoa(int data, char*p, int num);
data是傳入的帶轉(zhuǎn)化的數(shù)字,為整型變量(data的最大值為2的31次方減去1),p是傳入的字符型指針,指向存儲(chǔ)轉(zhuǎn)換后字符串空間的首地址;num指定要轉(zhuǎn)換成幾進(jìn)制的數(shù)字字符串(二進(jìn)制,八進(jìn)制,十進(jìn)制,十六進(jìn)制)。
如有不足之處,還望指正!?。?BR>
復(fù)制代碼 代碼如下:

// TestInheritance.cpp : 定義控制臺(tái)應(yīng)用程序的入口點(diǎn)。
//
#include "stdafx.h"
#include <iostream>
#include <string>
#include <math.h>
using namespace std;
int myItoa(int data, char* p, int num)
{
 if (p == NULL)
 {
  return -1;
 }
 if (data < 0)
 {
  *p++ = '-';
  data = 0 - data;
 }
 int temp = 0;
 int flag = 0; //標(biāo)志位 0-不存儲(chǔ) 1-存儲(chǔ)
 if (num == 10)
 {//十進(jìn)制
  for (int i = 0; i < 10; i++)
  {
   temp = static_cast<int>(data / pow(10.0, 9-i));// pow(i,j),求i的j次方,temp取得當(dāng)前最高位
   if (temp != 0)  //去掉最前面的0
   {
    flag = 1;//將標(biāo)志位變?yōu)?,可以存儲(chǔ)
   }
   if (flag != 0)
   {
    *p++ = temp + '0';  //變成字符
    data = data % static_cast<int>(pow(10.0, 9-i));
   }
  }
 }
 else if (num == 2)
 {//二進(jìn)制
  for (int i = 0; i < 32; i++)
  {
   temp = static_cast<int>(data / pow(2.0, 31-i)); //int型,存儲(chǔ)值最大為(2的31次方-1),
   if (temp != 0)
   {
    flag = 1;
   }
   if (flag != 0)
   {
    *p++ = temp + '0';
    data = data % static_cast<int>(pow(2.0, 31 - i));
   }
  }
 }
 else if (num == 16)
 {//十六進(jìn)制
  for (int i = 0; i < 8; i++)
  {
   temp = static_cast<int>(data / pow(16.0, 7-i));
   if (temp != 0)
   {
    flag = 1;
   }
   if (flag != 0)
   {
    if (temp >= 0 && temp <= 9)
    {
     *p++ = temp + '0';
    }
    else if (temp >= 10 && temp <= 15)
    {
     *p++ = temp - 10 + 'A';
    }
    data = data % static_cast<int>(pow(16.0, 7 - i));
   }
  }
 }
 else if (num == 8)
 {//八進(jìn)制
  for (int i = 0; i < 16; i++)
  {
   temp = static_cast<int>(data / pow(8.0, 15-i));
   if (temp != 0)
   {
    flag = 1;
   }
   if (flag != 0)
   {
    *p++ = temp + '0';
    data = data % static_cast<int>(pow(8.0, 15-i));
   }
  }
 }
}
int _tmain(int argc, _TCHAR* argv[])

 int i = 100;
 char a[32] ={0};
 char b[32] ={0};
 char c[32] ={0};
 char d[32] ={0};
 cout << i << "的八進(jìn)制表示為: ";
 myItoa(i, a, 8);
 cout << a << endl;
 cout << i << "的十進(jìn)制表示為: ";
 myItoa(i, b, 10);
 cout << b << endl;
 cout << i << "的二進(jìn)制表示為: ";
 myItoa(i, c, 2);
 cout << c << endl;
 cout << i << "的十六進(jìn)制表示為: ";
 myItoa(i, d, 16);
 cout << d << endl;
 return 0;
}

相關(guān)文章

  • C++移動(dòng)語(yǔ)義詳細(xì)介紹使用

    C++移動(dòng)語(yǔ)義詳細(xì)介紹使用

    首先,移動(dòng)語(yǔ)義和完美轉(zhuǎn)發(fā)這兩個(gè)概念是在C++的模板編程的基礎(chǔ)上,新增的特性,主要是配合模板來(lái)使用。本篇會(huì)從C++的值類型,到移動(dòng)拷貝與移動(dòng)賦值來(lái)理解移動(dòng)語(yǔ)義與完美轉(zhuǎn)發(fā)
    2023-01-01
  • C語(yǔ)言多文件編程問(wèn)題解析

    C語(yǔ)言多文件編程問(wèn)題解析

    在某些場(chǎng)景中,考慮到編譯效率和可移植性,#pragma once 和 #ifndef 經(jīng)常被結(jié)合使用來(lái)避免頭文件被 重復(fù)引入,這里介紹用 _Pragma 操作符避免頭文件重復(fù)引入的問(wèn)題,感興趣的朋友跟隨小編一起看看吧
    2022-12-12
  • c語(yǔ)言冒泡排序法代碼

    c語(yǔ)言冒泡排序法代碼

    c語(yǔ)言冒泡排序法代碼,這個(gè)是大家最早接觸的算法吧,總在寫(xiě) 總在錯(cuò),學(xué)習(xí)就是這么個(gè)過(guò)程, 溫故才知新, 望自己謹(jǐn)記
    2013-02-02
  • C語(yǔ)言版猜數(shù)字小游戲

    C語(yǔ)言版猜數(shù)字小游戲

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言版猜數(shù)字小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • C語(yǔ)言二叉樹(shù)的非遞歸遍歷實(shí)例分析

    C語(yǔ)言二叉樹(shù)的非遞歸遍歷實(shí)例分析

    這篇文章主要介紹了C語(yǔ)言二叉樹(shù)的非遞歸遍歷,包括了先序遍歷、中序遍歷與后序遍歷,需要的朋友可以參考下
    2014-09-09
  • C語(yǔ)言實(shí)現(xiàn)三子棋小游戲全程詳解

    C語(yǔ)言實(shí)現(xiàn)三子棋小游戲全程詳解

    完成一個(gè)三子棋的代碼并不是很難,有困難且重要的是完成這個(gè)游戲代碼所具備的思想,因?yàn)樗枷肷系倪M(jìn)步才是真正的進(jìn)步,當(dāng)我們有了這個(gè)思想上的武器,寫(xiě)出別的代碼,難度就不會(huì)高
    2022-05-05
  • STl中的排序算法詳細(xì)解析

    STl中的排序算法詳細(xì)解析

    全排序即把所給定范圍所有的元素按照大小關(guān)系順序排列。sort采用的是成熟的"快速排序算法"(目前大部分STL版本已經(jīng)不是采用簡(jiǎn)單的快速排序,而是結(jié)合內(nèi)插排序算法)
    2013-09-09
  • C++對(duì)cin輸入字符的判斷及分段函數(shù)處理方法示例

    C++對(duì)cin輸入字符的判斷及分段函數(shù)處理方法示例

    這篇文章主要介紹了C++對(duì)cin輸入字符的判斷及分段函數(shù)處理方法,結(jié)合實(shí)例形式分析了C++輸入判斷及處理相關(guān)操作技巧,需要的朋友可以參考下
    2017-09-09
  • ipv6實(shí)現(xiàn)udp編程示例

    ipv6實(shí)現(xiàn)udp編程示例

    這篇文章主要介紹了ipv6實(shí)現(xiàn)udp編程示例,需要的朋友可以參考下
    2014-03-03
  • C語(yǔ)言函數(shù)調(diào)用約定和返回值詳情

    C語(yǔ)言函數(shù)調(diào)用約定和返回值詳情

    這篇文章主要介紹了C語(yǔ)言函數(shù)調(diào)用約定和返回值詳情,函數(shù)調(diào)用約定不同,會(huì)影響函數(shù)生成的符號(hào)名,函數(shù)入?yún)㈨樞?,形參?nèi)存的清理者,更多相關(guān)需要的小伙伴可以參考下文詳情介紹
    2022-07-07

最新評(píng)論