源代码:

 #include "stdafx.h"  //必须写在首行,因为其前面的include都会被忽略
#include "omp.h"
#include <Windows.h>
#include "time.h"
#include <iostream>
#include <set>
using namespace std;

  //串行方式
set<int> FinishedNumber(int n)
{
set<int> s;
for (int i = ; i <= n; i++)
{
int maxv = (int)(sqrt(double(i)) + );
int sum = ;
for (int j = ; j<maxv; j++)
if (i%j == )
sum += j + i / j;
if (sum == i)
s.insert(i);
}
return s;
}   //并行方式
set<int> FinishedNumber(int n, int p)
{
set<int> s;
omp_set_num_threads(p);
#pragma omp parallel
#pragma omp for
for (int i = ; i <= n; i++)
{
int maxv = (int)(sqrt(double(i)) + );
int sum = ;
for (int j = ; j<maxv; j++)
if (i%j == )
sum += j + i / j;
if (sum == i)
s.insert(i);
}
return s;
} void Test(int step, int count)
{
/*int step=100000;
int count=5;*/
for (int i = ; i <= count; i++)
{
int n = i*step;
clock_t start_Serial = clock(); set<int> result = FinishedNumber(n);
printf("n=%d以内的所有完数为:\n", n);
for (set<int>::iterator it = result.begin(); it != result.end(); it++)
{
/*cout<<*it<<endl;*/
printf("%d\n", *it);
} clock_t end_Serial = clock();
double timeCollapsedSerial = end_Serial - start_Serial;
printf("n=%d, 串行方式运行耗时:%f\n", n, timeCollapsedSerial); int p = ;
double timeCollapsedParallel = ;
for (int power = ; power<; power++)
{
p = pow(, power);
clock_t start_Parallel = clock();
FinishedNumber(n, p);
clock_t end_Parallel = clock();
timeCollapsedParallel = end_Parallel - start_Parallel;
float accelerationRate = timeCollapsedSerial / timeCollapsedParallel;
printf("n=%d, p=%d, 并行方式运行耗时: %f,加速比: %.3f\n", n, p, timeCollapsedParallel, accelerationRate);
} printf("\n");
}
}
int _tmain(int argc, _TCHAR* argv[])
{
int step = * ;
int count = ;
Test(step, count);
system("pause");
}

运行结果:

OpenMP求完数的更多相关文章

  1. openmp 并行求完数

    // GetWanShu.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include "omp.h" #inclu ...

  2. 帮初学者改代码——playerc之“练习:求完数问题”(下)

    前文链接:帮初学者改代码——playerc之“练习:求完数问题”(上) 再来看看be_ferfect()应该如何改. be_ferfect()函数的功能是判断number是否为完数,同时把因子对写入d ...

  3. 帮初学者改代码——playerc之“练习:求完数问题”(上)

    原文:“练习:求完数问题” 原代码: // #include <stdio.h> #include <stdlib.h> #include <math.h> #de ...

  4. Java50道经典习题-程序9 求完数

    题目:一个数如果恰好等于它的因子之和,这个数就称为"完数".例如6=1+2+3.编程找出1000以内的所有完数. public class Prog9 { public stati ...

  5. 蓝桥杯 算法训练 ALGO-152 8-2求完数

     算法训练 8-2求完数   时间限制:50.0s   内存限制:256.0MB 问题描述 如果一个自然数的所有小于自身的因子之和等于该数,则称为完数.设计算法,打印1-9999之间的所有完数. 样例 ...

  6. JAVA 基础编程练习题9 【程序 9 求完数】

    9 [程序 9 求完数] 题目:一个数如果恰好等于它的因子之和,这个数就称为"完数".例如 6=1+2+3.编程找出 1000 以内的 所有完数. package cskaoyan ...

  7. Java实现 蓝桥杯VIP 算法训练 求完数

    问题描述 如果一个自然数的所有小于自身的因子之和等于该数,则称为完数.设计算法,打印1-9999之间的所有完数. 样例输出 与上面的样例输入对应的输出. 例: 数据规模和约定 1-9999 publi ...

  8. ALGO-152_蓝桥杯_算法训练_8-2求完数

    记: 掌握完数的概念 AC代码: #include <stdio.h> int main(void) { int i,j,sum; ; i <= ; i ++) { sum = ; ...

  9. Problem09 求完数

    题目:一个数如果恰好等于它的因子之和,这个数就称为"完数". 分析:例如6=1+2+3. 编程找出1000以内的所有完数. 假如整数n除以m,结果是无余数的整数,那么我们称m就是n ...

随机推荐

  1. C# unmanaged function pointers for iOS

    C# unmanaged function pointers for iOS Just a reminder to myself when I need this thing next time fo ...

  2. ubuntu网络设置

    修改/etc/network/interfaces文件sudo gedit /etc/network/interfaces 贴出我的eth0设置,自己看情况修改:# The primary netwo ...

  3. ] 解决myeclipse中新建javaweb工程,无法使用Web App Libraries问题

    ] 解决myeclipse中新建javaweb工程,无法使用Web App Libraries问题 标签: myeclipsejavawebWeb App Libraries 2013-10-16 1 ...

  4. verilog描述表决器的两种方式简易分析

    命题:设计一个三变量表决器.真值表如下: 可以写出并简化得出公式:F=AB+BC+AC. 以下是两种算法: 第一种:仅从算法方面描述为:A.B.C的和大于1则输出结果为1,否则为0:源码如下: mod ...

  5. xStream完美转换XML、JSON

    xStream框架 xStream可以轻易的将Java对象和xml文档相互转换,而且可以修改某个特定的属性和节点名称,而且也支持json的转换: 前面有介绍过json-lib这个框架,在线博文:htt ...

  6. CF456B Fedya and Maths 找规律

    http://codeforces.com/contest/456/problem/B CF#260 div2 B Fedya and Maths Codeforces Round #260 B. F ...

  7. oracle唯一索引与普通索引的区别和联系以及using index用法

    oracle唯一索引与普通索引的区别和联系 区别:唯一索引unique index和一般索引normal index最大的差异是在索引列上增加一层唯一约束.添加唯一索引的数据列可以为空,但是只要尊在数 ...

  8. 思维导图-javascript(转)

    学习的道路就是要不断的总结归纳,好记性不如烂笔头,so,下面将po出8张javascript相关的思维导图. 思维导图小tips:思维导图又叫心智图,是表达发射性思维的有效的图形思维工具 ,它简单却又 ...

  9. Maven初级学习(二)Maven使用入门

    序,学习配置pom.xml,利用maven生成eclipes项目. 一.编写POM POM Project Obejct Model,项目对象模型. 编写pom.xml,新建文件夹hello-worl ...

  10. [译]Mongoose指南 - Model

    编译你的第一个model var xxSchema = new Schema({name: 'string', size: 'string'}); var Tank = mongoose.model( ...