首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读以下说明及C++程序代码,将应填入(n)处的语句写在对应栏内。 【说明】 本程序的功能是实现任意两个大整数的乘法运算,例如: 输入整数1:8934793850094505800243958034985058 输入整数2:234
阅读以下说明及C++程序代码,将应填入(n)处的语句写在对应栏内。 【说明】 本程序的功能是实现任意两个大整数的乘法运算,例如: 输入整数1:8934793850094505800243958034985058 输入整数2:234
admin
2010-01-15
40
问题
阅读以下说明及C++程序代码,将应填入(n)处的语句写在对应栏内。
【说明】
本程序的功能是实现任意两个大整数的乘法运算,例如:
输入整数1:8934793850094505800243958034985058
输入整数2:234584950989689084095803583095820923
二者之积:
209596817742739508050978890737675662366433464256830959194834854876 8534
【C++代码】
#include<iostream.h>
const int MAXINPUTBIT=100;
const int MAXRESULTBIT=500;
class LargeNumber{
int i,j;
int temp;
int one[MAXINPUTBIT+1];
int onebit; //one的位数
int two[MAXINPUTBIT+1];
int twobit; //two的位数
int result[MAXRESULTBIT+1];
public:
LargeNumber();
~LargeNumber();
int inputone(); //出错返叫0,否则返回1
int inputtwo(); //同上
void multiplication(); //乘
void clearresult(); //清零
void showresult(); //显示
};
LargeNumber∷LargeNumber()
{
for(i=0;i<=MAXINPUTBIT;i++)
{
one
=0;
two
=0;
}
onebit=0;
twobit=0;
inputone();
inputtwo();
}
LargeNumber∷~LargeNumber()
{
}
int LargeNumber∷inputone()
{
char Number[MAXINPUTBIT+1];
cout<<"Please enter one:";
cin>>Number;
i=0;
j=MAXINPUTBIT;
while(Number
!=’\0’)
i++;
onebit=i;
for(i--;i>=0;i--,j--)
{
if(int(Number
)>=48&&int(Number
)<=57)
(1); //由字符转换为数字
else
return 0;
}
return 1;
}
int LargeNumber∷inputtwo()
{
char Number[MAXINPUTBIT+1];
cout<<"Please enter two:";
cin>>Number;
i=0;
j=MAXINPUTBIT;
while(Number
!=’\0’)
i++;
twobit=i;
for(i--;i>=0;i--,j--)
{
if(int(Number
)>=48&&int(Number
)<=57)
two[j]=int(Number
-48); //由字符转换为数字
else
return 0;
}
return 1;
}
void LargeNumber∷multiplication() //乘法
{
clearresult();
int m;
for(i=MAXINPUTBIT;i>=0;i--)
{
temp=two
;
for(j=(2),m=MAXINPUTBIT;m>=0;m--,j--)
{
result[j]+=temp*one[m];
if(result[j]>9)
{
result[j-1]+=result[j]/10;
(3);
}
}
}
cout<<"one*two=";
showresult();
}
void LargeNumber∷showresult()
{
i=0;
while(result
==0&&i<=MAXRESULTBIT)
i++;
if(i>MAXRESULTBIT)
cout<<"0"; //输出0
for(;i<=MAXRESULTBIT;i++)
cout<<(4);
cout<<endl;
}
void LargeNumber∷clearresult()
{
for(i=0;i<=MAXRESULTBIT;i++)
(5);
}
void main()
{
LargeNumber a;
a.multiplication();
}
选项
答案
(1)one[j]=int(Number[i]-48) (2)MAXRESULTBIT-(MAXINPUTBIT-i) (3)result[j]%=10 (4)result[i] (5)result[i]=0
解析
本题考查用C++实现大整数的乘法运算。
题目要求程序能实现从键盘任意输入的两个大整数的乘法运算。在程序中定义了一个大整数类,在类中抽象了大整数的一些属性,如长度等,还声明了一些操作,有对大整数输入的操作和对大整数求乘积的操作等。下面来具体[分析]程序。
第(1)空在第一个大整数的输入函数中,根据此空后面的注释我们知道,其功能是把字符转换为数字。在这里需要注意的是,从键盘输入的是字符型的一串字符,此空所在的条件判断语句是用来把这串字符中的数字找出来,接下来就是此空,要求把字符型的数字转换为整型的数字,而字符型数字与整型数字之间的ASCⅡ码值相差48。从第二个大整数的输入函数中,我们也可以很容易知道此空答案为one[j]=int(Number
-48)。
第(2)空在对大整数求乘积的函数中,是一个循环的初始条件,从程序中不难看出,这个二重循环是用来实现对两个大整数求乘积的,而变量j是用来存放计算结果数组的当前下标的,根据乘法的规则,不难得出此空答案为MAXRESULTBIT-(MAXINPUTBIT-i)。
第(3)空也在求积的二重循环中,它是在语句if(result[j]>9)为真的情况下执行的语句,如果这个条件为真,说明当前需要进位,但到底是进几位,进位后余下的数又应该是多少呢?这就是这个条件判断语句下要完成的任务,从程序中不难看出,对于到底进几位这个问题已经解决,剩下的就是对进位后余数的处理,此空的任务就是求出进位后的余数并存放到数组的当前位置。所以,此空答案为result[j]%=10。
第(4)空在输出计算结果的函数中,从程序中可以看出,此空在_个循环中,循环的作用是输出计算结果,而计算结果存放在数组中,因此,这个循环是用来输出数组中的所有元素。因此,此空答案为result
。
第(5)空是在清除计算结果的函数中,函数中只有一个循环,此空就在循环下面,计算结果存放在数组中,要清除计算结果就是把数组清零,那么此空的任务是把数组中的每个元素变成零,因此,此空答案为result
=0。
转载请注明原文地址:https://kaotiyun.com/show/mBjZ777K
本试题收录于:
程序员下午应用技术考试题库软考初级分类
0
程序员下午应用技术考试
软考初级
相关试题推荐
在Excel2010的A1单元格中输入函数“=ABS(ROUND(-1.478,2))”,按回车键后,A1单元格中的值为________________。
在Excel2010中,C3:C7单元格中的值分别为10、OK、20、YES和48,在。D7单元格中输入函数“=COUNT(C3:C7)”,按回车键后,D7单元格中显示的值为________________。
企业数字化转型是指企业在数字经济环境下,利用数字化技术和能力实现业务的转型、创新和增长。企业数字化转型的措施不包括()。
某单位的统计报表比较多,采用表号(报表的编号)的好处是______。
下列关于Windows操作系统文件名的说法,正确的是(32)。
要使Word能自动提醒英文单词的字母拼写是否正确,应设置Word的(47)选项功能。
在统计学中,用来衡量一个样本中各个数据波动大小的量是______。
以下定性的分类变量中,(9)属于有序变量(能排序)。
文件的扩展名可以说明文件类型。下面的“文件类型一扩展名”对应关系错误的是:
框架在网页布局中主要起什么作用?主页中定义了几个框架,分别显示哪个文档?假设连接的数据记录集当前指向的记录如下:写出以下ASP代码经过IIS服务器解释后的结果。<tdalign-"center"width="20%"><ahref
随机试题
长管从能量角度可略去()。
东北人“口重”即饮食过咸被证明是危险因素之一的疾病是
善治疗疮乳痈、毒蛇咬伤的药物是
根据中华人民共和国建设部令第3号《工程建设重大事故报告和调查程序规定》,下列属于一级重大事故的是( )。
组织实施职业健康安全管理体系的目的是()。
主营业务指标通常指主营业务收入占销售收入总额的比重,比重较大说明客户主营业务突出,经营方向明确;反之,则说明客户主营业务不够突出,经营方向不够明确。()
某外商投资企业银行存款(美元)账户上期期末余额为100000美元,上期末市场汇率为1美元=6.30元人民币,该企业外币交易采用当日即期汇率折算,以人民币作为记账本位币,按月计算汇兑损益。该企业本月10日将其中20000美元在银行兑换为人民币,银行当日美元买
如果资源和技术不变,单纯资本和人口的增长将达到增长的极限,人均收入增长也将停止。因为边际收益递减规律终将发生作用。()
Inthe2006filmversionofTheDevilWearsPrada,MirandaPriestly,playedbyMerylStreep,scoldsherunattractiveassistantf
一致性转变是态度转变的一种特殊形态,是指人们在态度转变过程中,如果总的态度方向不变,仅在倾向程度上有所变化,或者倾向程度增强,或者倾向程度减弱。一致性的态度转变存在以下四类:(1)从稍微赞成到非常赞成;(2)从非常赞成到稍微赞成;(3)从略为不赞成到
最新回复
(
0
)