12-global.cminus 648 Bytes
Newer Older
刘睿博's avatar
刘睿博 committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
int seed;

int randomLCG(void) {
    seed = seed * 1103515245 + 12345;
    return seed;
}

int randBin(void) {
    if (randomLCG() > 0)
        return 1;
    else
        return 0;
}

/* random walk */
int returnToZeroSteps(void) {
    int x;
    int steps;

    x = 0;
    steps = 0;

    while (steps < 20) {
        if (randBin())
            x = x + 1;
        else
            x = x - 1;

        steps = steps + 1;
        if (x == 0)
            return steps;
    }
    return 20;
}

int main(void) {
    int i;
    i = 0;

    seed = 3407;

    while (i < 20) {
        output(returnToZeroSteps());
        i = i + 1;
    }
    return 0;
}