pku 1426 Find The Multiple BFS

http://poj.org/problem?id=1426

首先补充一下基础知识:

一:常用数据类型对应字节数

       可用如sizeof(char),sizeof(char*)等得出

       32位编译器:

       char :1个字节
       char*(即指针变量): 4个字节(32位的寻址空间是2^32, 即32个bit,也就是4个字节。同理64位编译器)
       short int : 2个字节
       int: 4个字节
       unsigned int : 4个字节
       float: 4个字节
       double: 8个字节
       long: 4个字节
       long long: 8个字节
       unsigned long: 4个字节

       64位编译器:

       char :1个字节
       char*(即指针变量): 8个字节
       short int : 2个字节
       int: 4个字节
       unsigned int : 4个字节
       float: 4个字节
       double: 8个字节
       long: 8个字节
       long long: 8个字节
       unsigned long: 8个字节、

二:

在16位环境下,int/unsigned int 占16位,long/unsigned long占32位
  在32位环境下,int占32位,unsigned int占16位,long/unsigned long占32位
何时需要使用
  long 和 int 范围是[-2^31,2^31),即-2147483648~2147483647,而unsigned范围是[0,2^32),即0~4294967295,所以常规的32位整数只能够处理40亿左右,
遇到比40亿大的多的数就要用到64位
64位使用范围:
  不 同的编译器对64位整数的扩展有所不同,VC使用__int64/unsigned __int64,范围是[-2^63, 2^63)和[0,2^64),即-9223372036854775808~9223372036854775807与 0~18446744073709551615(约1800亿亿)。

注意点:
1、编译器不同导致使用64位的申明方式不同;
2、long long / unsigned long long 一般是Linux下申明方式、如:G++
3、__int64 /unsigned __int64一般是Windows下使用64位的申明方式,如:VS
4、在赋值时需要注意加上ll进行显式赋值;
5、当进行64位与 32位的混合运算时,32位整数会被隐式转换成64位整数。
6、输出printf("");,long long使用%lld输出,__int64使用%I64d,无符号使用u替代d即可。
7、测试下来编译器一般都支持2种操作,不必太过纠结,怎么使用看个人喜欢。

本来看到给的数据m < 100 long long 或者_int64的表示范围是 最大到二十位达不到100啊,所以搜了一下解题报告,看到直接用long long就行。、、

思路就是对所有可能的0,1组合搜索,知道遇到能够整出n的输出现。这里卡内存卡的很严,用stl的queue tle我用的循环队列过的。。

View Code
#include <iostream>

#include <cstdio>

#include <cstring>

#define maxn 800000

using namespace std;



int n;

__int64 q[maxn];

void bfs()

{

    int l = 0, r = 0;

    q[r++] = 1;

    while (l != r)

    {

        __int64 x = q[l++];

        l %= maxn;

        if (x%n == 0)

        {

            printf("%lld\n",x);

            break;

        }

        x *= 10;

        q[r++] = x;

        r %= maxn;

        x++;

        q[r++] = x;

        r %= maxn;

    }

}

int main()

{

    while (scanf("%d",&n))

    {

        if (!n) break;

        bfs();

    }

    return 0;

}

你可能感兴趣的:(find)