首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
打开考生文件夹下的解决方案文件proj3,其中声明了MagieNumber类,该类是一个用于表示连续正整数序列的类。MagicNumber的成员函数Intimacy的功能是查找该序列中的亲密数对。亲密数对的定义是:如果整数a的所有正因子(包括l,但不包括a
打开考生文件夹下的解决方案文件proj3,其中声明了MagieNumber类,该类是一个用于表示连续正整数序列的类。MagicNumber的成员函数Intimacy的功能是查找该序列中的亲密数对。亲密数对的定义是:如果整数a的所有正因子(包括l,但不包括a
admin
2020-12-21
37
问题
打开考生文件夹下的解决方案文件proj3,其中声明了MagieNumber类,该类是一个用于表示连续正整数序列的类。MagicNumber的成员函数Intimacy的功能是查找该序列中的亲密数对。亲密数对的定义是:如果整数a的所有正因子(包括l,但不包括a自身)之和等于b,并且整数b的所有正因子(包括1,但不包括b自身)之和等于a,则称整数a和b为亲密数对。
请根据亲密数的定义编写成员函数Intimacy。在main函数中给出了一组测试数据,此时程序的输出应该是:
1和1000之间的亲密数对为:
220和284
注意:只需在函数Filter的//*******333*******和//*******666*******之间填入若干语句,不要改动程序中的其他内容。
//MagicNumber.h
#include
#include
#inelude
#pragma warning(disable:4996)
using namespace std;
class MagicNumber
{
public:
MngicNumber(int x1,int x2):min(x1).max(x2),count(0){}
void ResetCount(){count=0;}
int GetCount()const{return count;}
int GetSet(int index){return set[index];}
void Intimacy();//寻找亲密数对
void Print()
{
cout<<rain<<“和”<<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,1000);
obj.Intimacy();
obj.Print();
writeToFile(““);
return 0;
}
选项
答案
vojd MagieNumber::Intimacv() for(number=rain:number<max:number++) int i; //过滤已经处理过的亲密数对 bool exist=false; if(number==set[i]){ exit=ture; } if(exist) continue; int numberA=number; int nurnberB=0; int sumA=0,sumB=0: //求numherA的所有正因子之和sumA for(i=1;i<=numberA/2;i++)} |f(numberA%i==0)} sumA+=i; } } //判断sumA的合法性 if(sumA<min‖sumA>max‖sumA==mumber(A){ continue; } //让numberB等于sumA求numberB的所有正因子之和sumB numberB=sumA; for(i=1;i<=numberB/2;j++)} if(numberB%i==0){ sumB+=i: } } //判断numberA和numberB是否属于亲密数对若是存入set数组更新count if(sumB==number(A){ set[count++]=numberA; set[count++]=numberB; } }
解析
根据题意.Intimacy是求min和max之间的亲密数对,程序首先遍历min和max之间的所有整数,在遍历的过程中,判断当前的numberA是否处理过,如果处理过继续判断下一个数;然后求numberA的正因子之和sumA,如果sumA不在min和max之间,或sumA等于numberA,说明当前sumA不合法,继续处理下一个数:否则sumA赋给numberB,求numberB的正因子之和sumB,最后判断sumB是否与numberA相等,如果相等,说明numberA和numberB属于亲密数对,存入set数组并更新count。
转载请注明原文地址:https://jikaoti.com/ti/JYl0FFFM
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
下列模板声明中,有语法错误的是( )。
若语句: cout<<setfill(’>’)<<setw(5)<<3141512<<setw(5)<<"OK!"; 是程序中第一个输出语句,则输出结果是
已知类MyClass声明如下:classMyClass{intn;public:MyClass(intk):n(k){}intgetValue()const{returnn;}};在下列数组定义中正确的是
有如下类定义: Class MyClass{ int value; public: MyClass(int n): value(n){} int getValue()const{return value;}
在重载一个运算符为成员函数时,其参数表中没有任何参数,这说明该运算符是
以下程序中调用cin函数给变量a输入数值的方法是错误的,其错误原因是 #include voidmain() {int*p,*q,a,b; p=&a; cout<<"inputa:"; cin>>p; }
使用VC6打开考生文件夹下的源程序文件modi2.cpp。阅读下列函数说明和代码,实现函数sort(intA[].int.n),用选择排序法把数组从大到小排序。提示:选择排序法的思想是:(1)反复从还未排好的那部分线性表中选择出关键字最
使用VC6打开考生文件夹下的源程序文件modi3.cpp。其中定义的类并不完整,按要求完成下列操作,将类的定义补充完整。(1)定义类的公有数据成员函数No、Name[32],其中No是int型的数据,Name[32]为字符型。请在注释//****
关键字unsigned不能修饰的类型是()。
定义学生选修课程的关系模式:SC(S#,Sn,C#,Cn,G)(其属性分别为学号、姓名、课程号、课程名、成绩)该关系的范式最高达到
随机试题
=________.
2岁正常小儿平均体重约为出生体重的
下列有关股骨的叙述,错误的是
A、全面系统,认真细致B、综合分析,切忌片面C、全神贯注,语言得当D、合理配伍,细致观察E、精诚团结,密切协作询问病史的伦理要求最主要的是
外渗性黏液囊肿常由哪种原因所致
(2011)电路如2.3一13图所示,设运算放大器有理想的特性,则输出电压uo为()。
课时计划也称教案,它是根据________、________安排并结合学生和场地器材的实际情况编写。
某年,冀城、豫城、徐城、兖城、青城等五座城市的游客量比往年偏多,这些城市分别有着不同的地理环境和旅游资源:险峻的高山、茂密的森林、平坦的草原、辽阔的大海和幽静的河谷。该年前往上述五座城市的游客量(人次/年)分别是:12万、27万、32万、44万、65万。已
下列各项生理活动中,属于条件反射的是
为了在Form_Load事件过程中用Print方法在窗体上输出指定的内容,首先应执行的操作是
最新回复
(
0
)