已知数据文件IN30.DAT中存有200个4位数 并已调用读函数readDat( )把这些数存入数组
已知数据文件IN30.DAT中存有200个4位数,并已调用读函数readDat( )把这些数存入数组a中,请编制一函数jsVal( ),其功能是:把个位数字和千位数字重新组合成一个新的十位数ab(新十位数的十位数字是原4位数的个位数字,新十位数的个位数字是原4位数的千位数字),以及把百位数和十位数组成另一个新的十位数cd(新十位数的十位数字是原4位数的百位数字,新十位数的个位数字是原4位数的十位数字),如果新组成的两个十位数必须是一个奇数,另一个为偶数且两个十位数中至少有一个数能被17整除,同时两个新十位数字均不为0,则将满足此条件的4位数按从大到小的顺序存入数组b中,并要计算满足上述条件的4位数的个数cnt,最后调用写函数writeDat( )把结果cnt及数组b中符合条件的4位数输出到OUT30.DAT文件中。
注意:部分源程序已给出。
程序中已定义数组:a[200],b[200],已定义变量:cnt。
请勿改动主函数main()、读函数readDat()和写函数writeDat()的内容。
参考解答
答案:
#include
#define MAX 200
int a[MAX,b[MAX,cnt=0;
void writeDat();
void jsVal( )
{
int i,j; /*定义循环控制变量*/
int a1,a2,a3,a4; /*定义变量保存4位数的每位数字*/
int temp; /*定义数据交换时的暂存变量*/
int ab,cd; /*存储重新组合成的十位数*/
for(i=0;i<200;i++) /*逐个取每一个4位数*/
{
a4=a[i/1000; /*求4位数的千位数字*/
a3=a[i%1000/100; /*求4位数的百位数字*/
a2=a[i%100/10; /*求4位数的十位数字*/
a1=a[i%10; /*求4位数的个位数字*/
ab=10*a1+a4; /*把个位数和千位数组合成一个新的十位数ab*/
cd=10*a3+a2; /*把百位数和十位数组成另一个新的十位数cd*/
if((ab%17==0||cd%17==0)&&((ab%2==0 && cd%2==1)||(ab%2==1 && cd%2==0)) && a1!=0 && a3!=0)
{ /*如果新组成的两个十位数必须是一个奇数,另一个为偶数且两个十位数中至少有一个数能被17整除,同时两个新十位数的十位上的数字均不为0*/
b[cnt=a[i; /*则将满足条件的数存入数组b中*/
cnt++; /*统计满足条件的数的个数*/
for(i=0;i
for(j=i+1;j
if(b[i
{
temp=b[i;
b[i=b[j;
b[j=temp;
void readDat( )
{
int i;
FILE *fp;
fp=fopen('IN30.DAT','r');
for(i=0;i
fscanf(fp,'%d',&a[i);
fclose(fp);
void main()
{
int i;
readDat();
jsVal();
printf('满足条件的数=%d\n',cnt);
for(i=0;i
printf('%d ',b[i);
printf('\n');
writeDat();
void writeDat()
{
FILE *fp;
int i;
fp=fopen('OUT30.DAT','w');
fprintf(fp,'%d\n',cnt);
for(i=0;i
fprintf(fp, '%d\n',b[i);
fclose(fp);
相似问题
( )是用户和设计交换最频繁的方法A.原型化方法B.瀑布模型方法C.螺旋模型方法D.构件组装模型
( )是用户和设计交换最频繁的方法A 原型化方法B 瀑布模型方法C 螺旋模型方法D 构件组装模型
( )方法根据输出对输入的依赖关系设计测试用例。A.路径测试B.等价类C.因果图D.归纳测试
( )方法根据输出对输入的依赖关系设计测试用例。A 路径测试B 等价类C 因果图D 归纳测试
下列不属于DFD方法基本元素的是( )。A.数据流B.数据处理C.数据存储D.数据结构
下列不属于DFD方法基本元素的是( )。A 数据流B 数据处理C 数据存储D 数据结构
下列不属于信息系统需求分析常用建模方法的是( )。A.ERB.IDEFOC.DFDD.UML
下列不属于信息系统需求分析常用建模方法的是( )。A ERB IDEFOC DFDD UML
简述从软件的架构层次来看嵌入式软件系统模型的分类。
简述从软件的架构层次来看嵌入式软件系统模型的分类。