sieve500.c

来自「arm单片机的ucos2移植」· C语言 代码 · 共 2,058 行 · 第 1/2 页

C
2,058
字号
#include "uhal.h"
#include <time.h>
#define MMAX 50000
#define iter 100
long passes, i, j;
char p[MMAX];
int t1, t2, k;

char *test_name = "Sieve 500 Test" ;
char * test_ver = "\nProgram Version 1.0\n";

int init_test(void)
{
	uHALr_printf ("Start, number of iterations: %i\n", iter);

	return 0;
}

int test()
{

    t1 = clock();
    for (k = 0; k < iter; k++)
      {

	for (i = 0; i < MMAX; i++)
	    p[i] = 1;
	i = 2;
	while (i < MMAX / 2)
	  {
	    j = 2 * i;
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;
		 j = j + i;
	    }
	    if (j < MMAX) {
		p[j] = 0;

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?