第25講 n進数の演算---その1 加法
第11話 プログラム解説その5
プログラム主要再掲
int g(int* a,int* b,int* c,int n){
   int i,j,k,d[10000],e[10000];
   for(i=0;;i++){
     if(a[i]==n){
        j=i;
        break;
     }
   }
   for(i=0;;i++){
     if(b[i]==n){
        k=i;
        break;
     }
   }
   if(j>=k){
     for(i=0;i<=j+2;i++){
        c[i]=0;
        d[i]=0;
        e[i]=0;
     }
     for(i=0;i<j;i++)d[i]=a[i];
     for(i=0;i<k;i++)e[i]=b[i];
     for(i=0;i<j;i++){
        c[i]+=(d[i]+e[i]);
        c[i+1]+=c[i]/n;
        c[i]=c[i]%n;
     }
     for(i=j+2;;i--){
        if(c[i]>0){
           c[i+1]=n;
           return(i+1);
        }
     }
   }
   else{
     for(i=0;i<=k+2;i++){
        c[i]=0;
        d[i]=0;
        e[i]=0;
     }
     for(i=0;i<k;i++)d[i]=b[i];
     for(i=0;i<j;i++)e[i]=a[i];
     for(i=0;i<k;i++){
        c[i]+=(d[i]+e[i]);
        c[i+1]+=c[i]/n;
        c[i]=c[i]%n;
     }
     for(i=k+2;;i--){
        if(c[i]>0){
          c[i+1]=n;
          return(i+1);
        }
     }
   }
}

核心部分
     for(i=0;i<j;i++){
        c[i]+=(d[i]+e[i]);
        c[i+1]+=c[i]/n;
        c[i]=c[i]%n;
     }
のトレースの続けていきます。
  t
i=3のとき、
        c[3]=c[3]+(d[3]+e[3]);
  今回も繰り上がりがありませんでしたから、
        c[3]=0+(4+0);
  の計算から
        c[3]=4;
  p
  次の行
        c[3+1]=c[3+1]+c[3]/5;
  により、
        c[4]=c[4]+c[4]/5;
        c[4]=0+4/5;
        c[4]=0;

  今回も625の位(左から5番目の位)への繰り上がりはありません。
  最後の行
        c[4]=c[4]%5;
  は
        c[4]=4%5;
  ですから、
        c[4]=4;
  で修正されません。

i=4のとき、
        c[4]=c[4]+(d[4]+e[4]);
  今回も繰り上がりがありませんでしたから、
        c[4]=0+(0+0);
  の計算から
        c[0]=0;
  q
  次の行
        c[4+1]=c[4+1]+c[4]/5;
  により、
        c[5]=c[5]+c[4]/5;
        c[5]=0+0/5;
        c[5]=0;

  今回も左から6番目の位への繰り上がりはありません。
  最後の行

        c[5]=c[5]%5;
  は
        c[5]=0%5;
  ですから、
        c[5]=5;
  で修正されません。

以上の進行により
  q
が見事に計算されています。





第10話へ 第12話へ

a

eclipse c++ 入門講義第1部へ

eclipse c++ 入門講義第2部へ


魔方陣 数独で学ぶ VBA 入門
数独のシンプルな解き方・簡単な解法の研究
VB講義へ
VB講義基礎へ
初心者のための世界で一番わかりやすいVisual C++入門基礎講座
初心者のための世界で一番わかりやすいVisual Basic入門基礎講座
初心者のための世界で一番わかりやすいVBA入門講義(基礎から応用まで)
初心者のための VC++による C言語 C++ 入門 基礎から応用まで第1部
eclipse java 入門
java 入門 サイト 基礎から応用まで
VC++ C言語 C++ 入門 初心者 基礎から応用まで
本サイトトップへ