Chinaunix首页 | 论坛 | 博客
  • 博客访问: 39947
  • 博文数量: 64
  • 博客积分: 2640
  • 博客等级: 少校
  • 技术积分: 670
  • 用 户 组: 普通用户
  • 注册时间: 2010-01-26 13:15
文章分类
文章存档

2010年(64)

我的朋友
最近访客

分类: C/C++

2010-01-26 14:03:08

 2009-03-24 16:25

#include<iostream>
#include<fstream>
using namespace std;

struct BigNum{
       int len,num[600];
       BigNum(){
             len = 1;
             memset(num,0,sizeof(num) );
       }
};

const int SIZE = 1000;

ostream& operator<<(ostream& out,const BigNum& n);
void operator*=(BigNum& n,int t);

int main(void){
    BigNum N;
    ofstream out("2^n.out");
   
    N.num[0] = 1;
    for(int i=0;i<SIZE;i++){
        out<<N<<endl<<endl;
        N *= 2;
    }
    out<<N;
   
    return 0;
}

void operator*=(BigNum& n,int t){
     int i,j;
    
     for(i=0;i<n.len;i++)
         n.num[i]*=t;
        
     for(i=0;i<n.len;i++){
         n.num[i+1] += n.num[i]/10;
         n.num[i] %= 10;
     }
    
     if(n.num[n.len]>0) n.len++;
}

ostream& operator<<(ostream& out,const BigNum& n){
         for(int i=n.len-1;i>=0;i--)
             out<<n.num[i];
            
         return out;
}


阅读(208) | 评论(0) | 转发(0) |
0

上一篇:DFS版拓扑排序

下一篇:邻接表版BFS

给主人留下些什么吧!~~