}
二、.根据程序功能填空。
1.程序把10个数存储到一维数组a中,并求该数组中最大值。
#include
voidmain()
{intmax;
inta[10]={76,55,95,87,85,83,65,90,77,85};
int*p=;
max=*p;
for(;p<;p++)
if(*p>max)max=;
cout<<"max="<}
2.下面程序的功能是输出1至100之间每位数字的乘积大于每位数的和的数。
例如,45两位数字的乘积为4×5=20,和为4+5=9。
#include
voidmain()
{intn,k=1,s=0,m;
for(n=1;n<=100;n++)
{k=1;s=0;
;
while()
{k*=m%10;
s+=m%10;
;
}
if(k>s)cout<}
}
3.程序对输入的n求s=1+1/23+1/33+…+1/n3。
#include
voidmain()
{doubles;inti,n;
cout<<"n=";cin>>n;
s=0;
for(i=1;;i++)
s=;
cout<<"s="<
}
4.函数create从键盘输入整数序列,以输入0为结束。
按输入顺序建立一个以head为表头的单向链表。
structnode{intdata;node*next;};
create()
{node*p,*q;
p=newnode;
cin>>p->data;
q=p;
while()
{if(head==NULL)head=p;
else;
q=p;
;
cin>>p->data;
}
q->next=NULL;
deletep;
}
5.以下程序求方程的全部整数解:
3x+2y-7z=5(0≤x,y,z≤100)
#include
voidmain()
{intx,y,z;
for(x=0;x<=100;x++)
for(y=0;y<=100;y++)
{if((z=3*x+2*y-5)%7)
;
;//求出z的值
if()//检查z的范围
cout<<"x="<}
}
三、程序设计
1.编写函数输出以下形状的图形,其中构成图形的数字和输出的行数通过参数传送。
1
222
33333
4444444
2.请编程序,输入两个正整数啊a和b(a
每行输出数据不超过10个。
例如,若输入a为6,b为8,则输出格式要求如下:
thefactorsof6:
23
thefactorsof7:
nofactor
thefactorsof8:
24
3.请编程序,找出1至99之间的全部同构数。
同构数是这样一组数:
它出现在平方数的右边。
例如:
5是25右边的数,25是625右边的数,所以5和25都是同构数。
4.编写一个程序,实现如下功能:
(1)从键盘输入aopb。
其中a,b为数值;op为字符,限制为+、-、*、/。
(2)调用函数count(op,a,b),计算表达式aopb的值。
由主函数输出结果。
5.编写一个程序,实现如下功能:
(1)输入k(<100)个整数到数组x[100]中;
(2)计算k个数的平均值及大于平均值的元素个数。
6.定义函数
voidreversion(intary[],intsize);
逆置数组ary的元素。
例如实参数组原来为[1,5,3,2,6,8,9,4],调用函数
reversion后变成为[4,9,8,6,2,3,5,1]。
7.数组a包含50个整数,把a中所有的后项除以前项之商取整后存入数组b(即b[i]=a[i]/a[i-1],并且b[50]=a[20]/a[1]),最后按每行5个元素的格式输出数组b。
8.编程输出所有不超过100的其平方具有对称性质的正整数(也称回文数)。
输出格式如下:
numbersquare
11
24
39
11121
22484
26676
9.编写程序,打印如下杨辉三角。
1
11
121
1331
14641
10.定义一个函数,计算长度为k的整型数组元素的平均值及大于平均值的元素个数。
调用函数的语句为:
count(a,k,ave,num);
其中a是数组名,k是数组元素个数,ave返回的平均值,num返回大于平均值的元素个数。