zoukankan      html  css  js  c++  java
  • 电路测试

    #include <iostream>
    #include <mpi.h>
    #include <stdio.h>
    #include <cstdio>
    
    using namespace std;
    
    int main(int argc,char* argv[])
    {
        int i;
        int id;
        int p;
        void check_circuit(int,int);
    
        MPI_Init(&argc,&argv);
        MPI_Comm_rank(MPI_COMM_WORLD,&id);
        MPI_Comm_size(MPI_COMM_WORLD,&p);
    
        for(i=id;i<65536;i+=p)
        {
            check_circuit(id,i);
        }
        printf("Process %d is done\n",id);
        fflush(stdout);
        MPI_Finalize();
    
        return 0;
    }
    
    
    #define EXTRACT_BIT(n,i) ((n&(1<<i))?1:0)
    
    void check_circuit(int id,int z)
    {
        int v[16];
        int i;
        for(i=0;i<16;i++)
        {
            v[i] = EXTRACT_BIT(z,i);
        }
    
        if((v[0] || v[1]) && (!v[1] || !v[3]) && (v[2] || v[3])
           && (!v[3] || !v[4]) && (v[4] || !v[5])
           && (v[5] || !v[6]) && (v[5] || v[6])
           && (v[6] || !v[15]) && (v[7] || !v[8])
           && (!v[7] || !v[13]) && (v[8] || v[9])
           && (v[8] || !v[9]) && (!v[9] || !v[10])
           && (v[9] || v[11]) && (v[10] || v[11])
           && (v[12] || v[13]) && (v[13] || !v[14])
           && (v[14] || v[15]))
        {
            printf("%d)%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d\n",id,
                   v[0],v[1],v[2],v[3],v[4],v[5],v[6],v[7],v[8],v[9],v[10],
                   v[11],v[12],v[13],v[14],v[15]);
            fflush(stdout);
        }
    }

    加入计数和时间:

    #include <iostream>
    #include <mpi.h>
    #include <stdio.h>
    #include <cstdio>
    
    using namespace std;
    
    int main(int argc,char* argv[])
    {
        int global_solutions;
        int i;
        int id;
        int p;
        double elapsed_time;
        int solutions;
        int check_circuit(int,int);
    
        MPI_Init(&argc,&argv);
        MPI_Barrier(MPI_COMM_WORLD);
        elapsed_time = -MPI_Wtime();
        MPI_Comm_rank(MPI_COMM_WORLD,&id);
        MPI_Comm_size(MPI_COMM_WORLD,&p);
        solutions = 0;
    
        for(i=id;i<65536;i+=p)
        {
            solutions += check_circuit(id,i);
        }
    
        MPI_Reduce(&solutions,&global_solutions,1,MPI_INT,MPI_SUM,0,MPI_COMM_WORLD);
        elapsed_time += MPI_Wtime();
        printf("Process %d is done\n",id);
        fflush(stdout);
        MPI_Finalize();
        if(id == 0)
        {
            printf("There are %d different solutions\n",global_solutions);
        }
        printf("loss time:%f\n",elapsed_time);
        return 0;
    }
    
    
    #define EXTRACT_BIT(n,i) ((n&(1<<i))?1:0)
    
    int check_circuit(int id,int z)
    {
        int v[16];
        int i;
        for(i=0;i<16;i++)
        {
            v[i] = EXTRACT_BIT(z,i);
        }
    
        if((v[0] || v[1]) && (!v[1] || !v[3]) && (v[2] || v[3])
           && (!v[3] || !v[4]) && (v[4] || !v[5])
           && (v[5] || !v[6]) && (v[5] || v[6])
           && (v[6] || !v[15]) && (v[7] || !v[8])
           && (!v[7] || !v[13]) && (v[8] || v[9])
           && (v[8] || !v[9]) && (!v[9] || !v[10])
           && (v[9] || v[11]) && (v[10] || v[11])
           && (v[12] || v[13]) && (v[13] || !v[14])
           && (v[14] || v[15]))
        {
            printf("%d)%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d\n",id,
                   v[0],v[1],v[2],v[3],v[4],v[5],v[6],v[7],v[8],v[9],v[10],
                   v[11],v[12],v[13],v[14],v[15]);
            fflush(stdout);
            return 1;
        }
        else
        {
            return 0;
        }
    }
  • 相关阅读:
    多重继承
    单继承
    访问限制方法
    猜字游戏
    getSet方法
    访问限制
    __str__函数
    析构函数
    构造函数二
    选择排序
  • 原文地址:https://www.cnblogs.com/wn19910213/p/3457167.html
Copyright © 2011-2022 走看看