fak.c
author Markus Bröker <mbroeker@largo.dyndns.tv>
Thu, 16 Apr 2009 12:50:39 +0200
changeset 73 d0578510aea1
parent 63 5a82f89d607e
child 77 49e0babccb23
permissions -rw-r--r--
Changelog: Makefile and sort.c Makefile: * Environment Variable Profiler=<target> sort.c: * Quick Sort Algorithm implemented committer: Markus Bröker <mbroeker@largo.homelinux.org>

/**
 * test/demos/fak.c
 * Copyright (C) 2008 Markus Broeker
 */

#include <stdio.h>
#include <stdlib.h>

unsigned long fak (short i)
{
    if (i == 0)
        return 1;
    else if (i > 0)
        return (i * fak (i - 1));
    else
        return (i * fak (i + 1));
}

int main (int argc, char **argv)
{
    short number;

    printf ("Enter a number: ");
    if (scanf ("%hd", &number) != 1) {
        printf ("READ ERROR\n");
        return EXIT_FAILURE;
    }

    if (number < 0) {
        printf ("NUMBER FORMAT ERROR\n");
        return EXIT_FAILURE;
    }

    printf ("The faktorial of %d is %lu\n", number, fak (number));

    return EXIT_SUCCESS;
}