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

C++實現(xiàn)十進(jìn)制數(shù)轉(zhuǎn)換為二進(jìn)制數(shù)的數(shù)學(xué)算法

 更新時間:2021年09月16日 09:57:08   作者:趙清詩  
這篇文章和大家分享一下我個人對十進(jìn)制數(shù)轉(zhuǎn)換為二進(jìn)制數(shù)的想法,目前暫時更新只整數(shù)十進(jìn)制的轉(zhuǎn)換,后續(xù)會更新帶有小數(shù)的進(jìn)制轉(zhuǎn)換,代碼使用c++實現(xiàn)

一、十進(jìn)制轉(zhuǎn)換為二進(jìn)制的數(shù)學(xué)算法

設(shè)目標(biāo)十進(jìn)制數(shù)為n,用短除法一直除以2,循環(huán)這個過程并記錄余數(shù),當(dāng)商為0時結(jié)束循環(huán),余數(shù)從后往前讀就是轉(zhuǎn)換為的二進(jìn)制數(shù)

eg:

在這里插入圖片描述

二、代碼實現(xiàn)

1.設(shè)計轉(zhuǎn)換函數(shù)transfer

// flag是位數(shù)控制器,用remainder來暫時保存每一位余數(shù),y是轉(zhuǎn)換的二進(jìn)制結(jié)果。我們的目標(biāo)是把流程結(jié)束后的余數(shù)倒序輸出 ,比如13的二進(jìn)制數(shù)1101,但是每次除以2后得到的余數(shù)都是個位數(shù),所以我選擇使用一個位數(shù)控制器flag,從初始值1開始和remainder相乘,然后迭代(每次乘以十)進(jìn)入下一次除以2的過程,然后每次迭代相加y就能得到二進(jìn)制數(shù)1101(其實這個1101是用十進(jìn)制顯示的),而我們知道,當(dāng)除數(shù)=0時就停止循環(huán),所以我們設(shè)置If條件來控制結(jié)束
演示一遍具體的循環(huán)流程:

 eg:13(10)----1101(2):
  1. remainder=n%2=1; n=n/2=6; y=y+remainder*flag=0+1*1=1;flag=flag*10=10;
  2. remainder=n%2=0; n=n/2=3; y=y+reminder*flag=1+0*10=1;
flag=flag*10=100;
  4. remainder=n%2=1; n=n/2=1; y=y+reminder*flag=1+1*100=101;
flag=flag*10=1000;
  5. remainder=n%2=1; n=n/2=0;y=y+reminder*flag=101+1*1000=1101;
flag=flag*10=10000;
此時n=0,if(n==0)成立,停止循環(huán),輸出y。
int transfer(int n)
{
    int flag=1,y=0,remainder; 
    while(1)
    {
        remainder=n%2;
        n/=2;
        y+= remainder*flag;
       flag*=10;
        if(n==0)
        {
            break;
        }
    }
    return y;
}

2.完整代碼

代碼如下(示例):

#include <cstdio>
#include<iostream>
using namespace std;
int a[1000001];
int main()
{
    int transfer(int n);
    int n,sum=0,y;
    scanf("%d",&n);
    y=transfer(n);   
    printf("%d\n",y);
    return 0;
}
int transfer(int n)
{
    int flag=1,y=0,remainder;
    while(1)
    {
        remainder=x%2;
        n/=2;
        y+=remainder*flag;
        flag*=10;
        if(n==0)
        {
            break;
        }
    }
    return y;
}

總結(jié)

其實籠統(tǒng)來說,主要的思想就是從位數(shù)由低到高,把余數(shù)依次乘以1,10,100,1000再加起來就是用十進(jìn)制的形式表示了轉(zhuǎn)換后的二進(jìn)制(1101=1乘1+0乘10+1乘100+1乘1000),需要注意的是位數(shù)控制器flag的使用。

以上就是C++實現(xiàn)十進(jìn)制數(shù)轉(zhuǎn)換為二進(jìn)制數(shù)的數(shù)學(xué)算法的詳細(xì)內(nèi)容,更多關(guān)于C++十進(jìn)制轉(zhuǎn)二進(jìn)制的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • C語言水仙花數(shù)的實現(xiàn)

    C語言水仙花數(shù)的實現(xiàn)

    這篇文章主要介紹了C語言水仙花數(shù)的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • C語言 循環(huán)詳解及簡單代碼示例

    C語言 循環(huán)詳解及簡單代碼示例

    本文主要介紹C語言的循環(huán)知識,這里整理了循環(huán)的基礎(chǔ)資料并附簡單的代碼示例詳細(xì)講解,有需要的小伙伴可以參考下
    2016-08-08
  • C++實現(xiàn)string存取二進(jìn)制數(shù)據(jù)的方法

    C++實現(xiàn)string存取二進(jìn)制數(shù)據(jù)的方法

    這篇文章主要介紹了C++實現(xiàn)string存取二進(jìn)制數(shù)據(jù)的方法,針對STL中string的用法進(jìn)行了較為詳細(xì)的分析,需要的朋友可以參考下
    2014-10-10
  • 將正小數(shù)轉(zhuǎn)化為2-9進(jìn)制小數(shù)的實現(xiàn)方法

    將正小數(shù)轉(zhuǎn)化為2-9進(jìn)制小數(shù)的實現(xiàn)方法

    本篇文章對正小數(shù)轉(zhuǎn)化為2-9進(jìn)制小數(shù)的實現(xiàn)方法進(jìn)行了介紹,需要的朋友參考下
    2013-05-05
  • C語言實現(xiàn)運籌學(xué)中的馬氏決策算法實例

    C語言實現(xiàn)運籌學(xué)中的馬氏決策算法實例

    這篇文章主要介紹了C語言實現(xiàn)運籌學(xué)中的馬氏決策算法,簡單介紹了馬氏決策的概念,并結(jié)合實例形式分析了C語言實現(xiàn)馬氏決策算法的具體實現(xiàn)技巧,需要的朋友可以參考下
    2017-09-09
  • Windows 環(huán)境下使用 Qt 連接 MySQL

    Windows 環(huán)境下使用 Qt 連接 MySQL

    這篇文章主要介紹了Windows 環(huán)境下使用 Qt 連接 MySQL的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • C/C++整數(shù)乘積的溢出問題的解決

    C/C++整數(shù)乘積的溢出問題的解決

    整數(shù)乘積的溢出問題是指兩個整數(shù)相乘得到的結(jié)果超過了所能表示的數(shù)據(jù)類型的范圍,本文給大家介紹了C/C++整數(shù)乘積的溢出問題的解決,需要的朋友可以參考下
    2024-02-02
  • C語言中枚舉與指針的實例詳解

    C語言中枚舉與指針的實例詳解

    這篇文章主要介紹了 C語言中枚舉與指針的實例詳解的相關(guān)資料,希望通過本文大家能夠掌握枚舉與指針的知識,需要的朋友可以參考下
    2017-09-09
  • C++設(shè)計模式之外觀模式(Facade)

    C++設(shè)計模式之外觀模式(Facade)

    這篇文章主要為大家詳細(xì)介紹了C++設(shè)計模式之外觀模式(Facade),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • C++?Boost?Lambda表達(dá)式詳解

    C++?Boost?Lambda表達(dá)式詳解

    Lambda?表達(dá)式(lambda?expression)是一個匿名函數(shù),Lambda表達(dá)式基于數(shù)學(xué)中的λ演算得名。本文就來為大家詳細(xì)講講C++中Lambda表達(dá)式的使用,需要的可以參考一下
    2022-11-11

最新評論