首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
打开考生文件夹下的解决方案文件proj3,其中声明了MagicNumber类,该类是一个用于表示连续正整数序列的类。MagicNumber的成员函数Intimacy的功能是查找该序列中的亲密数对。亲密数对的定义是:如果整数a的所有正因子(包括1,但不包括a
打开考生文件夹下的解决方案文件proj3,其中声明了MagicNumber类,该类是一个用于表示连续正整数序列的类。MagicNumber的成员函数Intimacy的功能是查找该序列中的亲密数对。亲密数对的定义是:如果整数a的所有正因子(包括1,但不包括a
admin
2020-04-10
49
问题
打开考生文件夹下的解决方案文件proj3,其中声明了MagicNumber类,该类是一个用于表示连续正整数序列的类。MagicNumber的成员函数Intimacy的功能是查找该序列中的亲密数对。亲密数对的定义是:如果整数a的所有正因子(包括1,但不包括a自身)之和等于b,并且整数b的所有正因子(包括l,但不包括b自身)之和等于a,则称整数a和b为亲密数对。
请根据亲密数的定义编写成员函数Intimacy。在main函数中给出了一组测试数据,此时程序的输出应该是:
1和1000之间的亲密数对为:
220和284
注意:只需在函数Filter的//*******333*******和//*******666*******之间填入若干语句,不要改动程序中的其他内容。
//MagicNumber.h
#include<iostream>
#include<string>
#include<cmath>
#pragma warning(disable:4996)
using namespace std;
class MagicNumber
{
public:
MagicNumber(int x1,int x2): min(x1),max(x2),count(C){}
void ResetCount(){count=0;}
int GetCount()const{return count;}
int GetSet(int index){return set[index];}
void Intimacy();//寻找亲密数对
void Print()
{
cout<<min<<"和"<<max<<"之间的亲密数为:"<<endl;
for(int i=0;i<count;i+=2)
cout<<set
<<"和"<<set[i+1]<<endl;
}
private:
int digits;//Magic数的位数
int min,max;//待计算的数值范围
int count;//Magic数的数量
int set[40];//Magic数集合
};
void writeToFile(const char*);
//main.cpp
#include"MagicNumber.h"
void MagicNumber::Intimacy()
{
int number;
for(number=min;number<max;number++)
{
//******333******
//******666******
}
}
int main()
{
MagicNumber obj(1,i000);
obj.Intimacy();
obj.Print();
writeToFile("");
return 0;
}
选项
答案
void MagicNumber::Intimacy() { int number; for(number=min; number<max;number++) { int i; //过滤已经处理过的亲密数对 bool exist=false; for(i=0;i<count; i++) { if(number==set[i]){ exist=true; } } if(exist){ continue; } int numberA=number; int numberB=0; int sumA=0,sumB=0; //求numberA的所有正因子之和surnA for(i=1; i<=numberA/2;i++) { if(numberA%i==0){ sumA+=i; } } //判断sumA的合法性 if(sumA<min || sumA>max || sumA==numberA){ continue; } //让numberB等于sumA求numberB的所有正因子之和sumB numberB=sumA; for(i=1;i<=numberB/2;i++){ if(numberB%i==0){ sumB+=i; } } //判断numberA和mumberB是否属于亲密数对若是存入set;数组更新count if(sumB==numberA){ set[count;++]=nuraberA; set[count++]:numberB; } } }
解析
根据题意,Intimacy是求rain和max之间的亲密数对,程序首先遍历rain和max之间的所有整数,在遍历的过程中,判断当前的numberA是否处理过,如果处理过继续判断下一个数;然后求numberA的正因子之和sumA,如果sumA不在min和max之间,或sumA等于numberA,说明当前sumA不合法,继续处理下一个数;否则sumA赋给numberB,求numberB的正因子之和sumB,最后判断sumB是否与numberA相等,如果相等,说明numberA和numberB属于亲密数对,存入set数组并更新count。
转载请注明原文地址:https://jikaoti.com/ti/SwA0FFFM
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
程序设计语言的工程特性之一为()。
A、 B、 C、 D、 B在引用函数模板时,如果没在函数名和参数之间加上类型参数,就默认表示参数类型严格按照模板定义的类型匹配;如果在函数名和参数之间加上了类型参数,则对实参自动进行类型转换。
有以下程序#include<iostream>usingnamespacestd;classComplex{public:Complex(d
一棵二叉树共有47个结点,其中有23个度为2的结点。假设根结点在第1层,则该二叉树的深度为【1】。
下列链表中,其逻辑结构属于非线性结构的是
线性表的顺序存储结构和线性表的链式存储结构分别是()。
下列关于虚函数与函数重载区别的叙述中不正确的是
在关系数据库中,把数据表示成二维表,每一个二维表称为【】。
诊断和改正程序中错误的工作通常称为______。
执行下列语句段后,输出字符“*”的个数是()。for(inti=50;i>l;I-=2)cout<<‘*’;
随机试题
曾经提出社会公平的复合理论的学者是()
同期控制
患者男,36岁,三个月前因外伤一上前牙脱落,今要求烤瓷修复。口腔检查:左上1缺失,间隙正常,牙槽嵴无明显吸收。右上1牙冠1/2缺损,已露髓,探稍敏感,叩诊阴性,无松动。左上2牙冠良好,叩诊阴性,无松动。上下前牙牙龈轻度红肿,易出血,可见菌斑及牙石。余牙末见
政府采购活跃市场经济的主要表现包括()。
东方股份有限公司(本题下称东方公司)系境内上市公司,2002年至2003年,东方公司发生的有关交易或事项如下:(1)2002年10月1日,东方公司与境外A公司签订一项合同,为A公司安装某大型成套设备。合同约定:①该成套设备的安装任务包括场地勘察、设
教师的专业化就是多提高有关学科的本体性知识。()
给定资料资料1随着经济社会发展,越来越多的人在度假方式上,开始追求一种闲适的节奏;或是在家陪陪家人、或在田园放松心灵、或做点无用的事……而这种观念也正是社会更加成熟自信、文明进步的一种表现。A市位于我国西部地区,具有丰富的旅游
移位指令中的()指令的操作结果相当于对操作数进行乘2操作。
"Down-to-earth"meanssomeoneorsomethingthatishonest,realisticandeasytodealwith.Itisapleasuretofind【31】______w
Childrenwhogriptheirpenstooclosetothewritingpointarelikelytobeatadisadvantageinexaminations,【C1】________toth
最新回复
(
0
)