银行有个存有n个用户编号的文件....输出:n个数升序排列....

/*银行有个存有n个用户编号的文件,每个数都小于n,其中n=10的7次方。每个编号都不重复。
* 输出:n个数升序排列。
* 约束条件:内存最多有2兆的空间,运行时间复杂度为O(n)。
*/

#include <iostream>
#include <fstream>

#define MAXSUM 312500 //312500 = (10000000 / 8 / 4)

//表示 (0-->31) 的各个bit上的"1"
const std::size_t s[32]={
    0x00000001,0x00000002,0x00000004,0x00000008,0x00000010,0x00000020,0x00000040,0x00000080,0x00000100,0x00000200,
    0x00000400,0x00000800,0x00001000,0x00002000,0x00004000,0x00008000,0x00010000,0x00020000,0x00040000,0x00080000,
    0x00100000,0x00200000,0x00400000,0x00800000,0x01000000,0x02000000,0x04000000,0x08000000,0x10000000,0x20000000,
    0x40000000,0x80000000
};

void Magnanimitysort()
{
    std::size_t *a;
    std::size_t b=1;
    std::size_t n=0;
    std::size_t n1=0,n2=0;

    a = (std::size_t*)malloc(sizeof(std::size_t)*MAXSUM); //申请一段内存空间,一个bit表示一个unsigned整数
    if(a==NULL)return ;

    memset(a,0,sizeof(std::size_t)*MAXSUM);

    std::ifstream file("src.txt");
    if(!file)
    {
        std::cout<<"打开文件失败!"<<std::endl;
        return ;
    }

    std::ofstream file2("result.txt");
    if(!file2)
    {
        std::cout<<"打开文件失败!"<<std::endl;
        return ;
    }

    while(!file.eof())
    {
        file>>n;
        n1=n/32; //n1 --> "unsigned int"地址,即n将要存放在哪个"unsigned int"
        n2=n%32; //n2 --> "unsigned int"的内部偏移量

        b=1;
        a[n1] = a[n1]|b<<n2;                
    }

    file.close();

    for(b=0;b<MAXSUM;++b)
    {
        /*if(a[b]==0)
		{
			break;
		}*/

        std::size_t i=0;
        for(i=0;i<32;i++)
        {
            std::size_t t = a[b]&s[i];
            if( t>0 )
            {
                //std::cout<<i+b*32<<"\n";
                file2<<i+b*32<<"\n";
            }
        }
    }

    file2.close();
    free(a);
    a=NULL;
}

int main()
{
    //createfile();
    Magnanimitysort();

	system("pause");
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值