第23講 n進数を10進数に翻訳する

第3話 16進数まで拡張する
m

を実現するプログラム例
#include<iostream>
#include<ctime>
using namespace std;
int f(int* y,int n);
void h(long long x,int* y,int n,int max);
void main(){
   srand(time(NULL));
   int y[10],n,max;
   int t=0;
   while(1){
    cout<<"何進数のデータを作成しますか?"<<endl;
    t=1;
    break;
   }
   if(t==1)scanf("%d",&n);
   max=f(y,n);
   h(0,y,n,max);
   cout<<"プロジェクト終了"<<endl;
}
int f(int* y,int n){
   int max,i;
   max=rand()%10;
   for(i=0;i<=max;i++){
    if(i==0){
       while(1){
         y[i]=rand()%n;
         if(y[i]>0)break;
       }
    }
    if(i>0)y[i]=rand()%n;
   }
   return(max);
}
void h(long long x,int* y,int n,int max){
   int i;
   cout<<n<<"進数の";
  
for(i=0;i<=max;i++){
    if(y[i]<10)cout<<y[i];
    if(y[i]==10)cout<<"A";
    if(y[i]==11)cout<<"B";
    if(y[i]==12)cout<<"C";
    if(y[i]==13)cout<<"D";
    if(y[i]==14)cout<<"E";
    if(y[i]==15)cout<<"F";
   }

   cout<<"は"<<endl;
   for(i=0;i<=max;i++){
    x+=y[i];
    if(i<max)x*=n;
   }
   cout<<x<<"です。"<<endl;
}
参考ダウンロード添付ファイル

次の改良です。
d
作った答えを逆にn進数に直して、
元と同じなるかを確認することによって、
検算して下さい。


第2話へ 第4話へ

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++ 入門 初心者 基礎から応用まで
本サイトトップへ