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

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

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

// TestInheritance.cpp : 定義控制臺應(yīng)用程序的入口點。
//
#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; //標志位 0-不存儲 1-存儲
 if (num == 10)
 {//十進制
  for (int i = 0; i < 10; i++)
  {
   temp = static_cast<int>(data / pow(10.0, 9-i));// pow(i,j),求i的j次方,temp取得當前最高位
   if (temp != 0)  //去掉最前面的0
   {
    flag = 1;//將標志位變?yōu)?,可以存儲
   }
   if (flag != 0)
   {
    *p++ = temp + '0';  //變成字符
    data = data % static_cast<int>(pow(10.0, 9-i));
   }
  }
 }
 else if (num == 2)
 {//二進制
  for (int i = 0; i < 32; i++)
  {
   temp = static_cast<int>(data / pow(2.0, 31-i)); //int型,存儲值最大為(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)
 {//十六進制
  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)
 {//八進制
  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 << "的八進制表示為: ";
 myItoa(i, a, 8);
 cout << a << endl;
 cout << i << "的十進制表示為: ";
 myItoa(i, b, 10);
 cout << b << endl;
 cout << i << "的二進制表示為: ";
 myItoa(i, c, 2);
 cout << c << endl;
 cout << i << "的十六進制表示為: ";
 myItoa(i, d, 16);
 cout << d << endl;
 return 0;
}

相關(guān)文章

  • C++移動語義詳細介紹使用

    C++移動語義詳細介紹使用

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

    C語言多文件編程問題解析

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

    c語言冒泡排序法代碼

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

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

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

    C語言二叉樹的非遞歸遍歷實例分析

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

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

    完成一個三子棋的代碼并不是很難,有困難且重要的是完成這個游戲代碼所具備的思想,因為思想上的進步才是真正的進步,當我們有了這個思想上的武器,寫出別的代碼,難度就不會高
    2022-05-05
  • STl中的排序算法詳細解析

    STl中的排序算法詳細解析

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

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

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

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

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

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

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

最新評論