メルマガ:あゆしゃのC言語プログラミング
タイトル:あゆしゃのC言語プログラミング(Vol.440) 大型計算機 10進数変換  2004/04/16


/*========================================================*/
    <<<あゆしゃのC言語プログラミング>>>
/*========================================================*/
 第440回 大型計算機 10進数変換
 発行    2004年4月16日(金曜日)
 発行数   約2900

{magclick}
/*========================================================*/
 はじめに ( 決り文句 )
/*========================================================*/
・このメールマガジンはまぐまぐさんから発行しています。
・ジャンルは、マルチメディアのプログラム、C言語です。
・このメールマガジンは、横60文字で作成しています。
 また、インデントはすべて半角スペース4つで構成しています。
・ここで扱うプログラムは、C言語と半光年以内のものです。
・登録解除は、まぐまぐさんのホームページでお願いします。
・まぐまぐさんのバックナンバー(下欄参照)を活用して下さい。
・ここは私の復習の場です。内容は約1ヶ月内外に私が勉強した
 内容になっています。最新の技術があれば、へたれもあります。
・わかりやすさを優先させる為、たまに嘘があるかもしれません。
・セキュリティ突破のため、暗号化された単語があります。

/*========================================================*/
 ご挨拶
/*========================================================*/

 こんにちは。あゆしゃです。

 ドdラrクエ、やっとマウンテンまでたどり着きました。

{magclick}
/*========================================================*/
 今回のお題  << 大型計算機 10進数変換 >>
/*========================================================*/

class CXInt;

enum { SIZE = 1024; }

UCHAR m_buff[ SIZE ];

/*========================================================*/

CXInt& add( CXInt& a );
CXInt& sub( CXInt& a );
CXInt& mul( CXInt& b );
CXInt& div( CXInt& b );
CXInt& shl( void );
CXInt& shr( void );
int cmp( CXInt& b );
CXInt& CXInt();
int getBit( int pos );
CXInt& setBit( int pos, int d = 1 );
CXInt& sqrt( void );
CXInt( CXInt& a );
CXInt& clear( void );
CXInt& pow( void );
CXInt copy( void );
CXInt& fromHex( LPCTSTR buff );
CString toHex( void );

/*========================================================*/

 今回は、10進数との変換です。
 まずは、文字列からCXIntへの変換です。

 文字列を下の桁から拾い、10倍しながら足すのが簡単で
しょうか。

CXInt& fromString( LPCTSTR buff );

clear();
CXInt a;
a.setBit( 1 ); // = 1;
int len = strlen( buff ) - 1;
int n;
for( int i = len; i >= 0; i-- )
{
if( n = xtoi( buff[ i ] ) ) add( a.copy().mul( n ) );
a.mul( 10 ); // 10倍
}
return *this;

 意外に簡単にできそうです。
 話の都合上、int との掛け算を作ったほうが、よさそうですね。

CXInt& mul( int b );

int d, c = 0;
for( int i = 0; i < SIZE; i++ )
{
d = ( int )m_buff[ i ] * b + c;
m_buff[ i ] = ( UCHAR )d;
c = d >> 8;
}
return *this;

 この b には上限がありますが、まぁ、気にしないでおきま
しょう。

/*========================================================*/

 続いて、10進数文字列への変換。これは厄介です。

 10進数文字列としての加算処理を作るのが、簡単でしょうか。

CString toString( void );

CXInt10 a;
CXInt10 b;
b.add( 1 );
int n;
for( int i = 0; i < SIZE; i++ )
{
if( n = m_buff[ i ] ) a.add( b.copy().mul( n ) );
b.a.mul( 16 ); // 16倍
}
CString st( a.m_buff );
st.Reverse();
return st;

 へ、変なクラスを作ってしまいました。

 でもこうすると、形がさっきと同じですね。

{magclick}
/*========================================================*/
 さいごに
/*========================================================*/

{magclick}
/*========================================================*/
 次回予告
/*========================================================*/

 次回は4月19日(月曜日)に、第441回を送ります。
 お題は「大型計算機 10進数計算」

 関数内部に計算をとどめようとしたのですが、難しくなり
すぎますので、というか面倒なので、クラスを1つ作ります。

 お楽しみに!

/*========================================================*/
 最後の決り文句
/*========================================================*/
 このメールマガジンは、まぐまぐさんから発行しています。
 このメールマガジンを解除したい場合は、まぐまぐさんをご利用
ください。このメルマガのまぐまぐアイディーは最後にあります。
 このメールマガジンには広告が挿入されていますか?
 このメールマガジンの内容に文面の引用はありませんか?
 めーらっくすの場合はめーらっくすの利用方に従ってください。
 このメールマガジンの内容の、転用、流用、宣伝、リンク、
パパ父の最期のシーンで体が動いてしまう なんて大歓迎です。

{magclick}
/*========================================================*/
 
/*========================================================*/

発行者 あゆしゃ

まぐまぐアイディー
0000020674

まぐまぐバックナンバー
http://jazz.tegami.com/backnumber/frame.cgi?id=0000020674

あゆしゃの世界
http://ayusya.hp.infoseek.co.jp/

登録と解除
http://www.mag2.com/m/0000020674.htm

ご意見・ご感想・ご質問メール
mailto:ayusya@flamenco.plala.or.jp

めーらっくす <<過去ログがタイトル別になっています>>
http://www.mailux.com/mm_dsp.php?mm_id=MM3E1AEE285AB4F

ブラウザの閉じるボタンで閉じてください。