首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请编写函数fun,函数的功能是:删去一维数组中所有相同的数,使之只剩一个。数组中的数已按由小到大的顺序排列,函数返回删除后数组中数据的个数。 例如,一维数组中的数据是:2 2 2 3 4 4 5 6 6 6 6 7 7 8 9 9 10 10 10
请编写函数fun,函数的功能是:删去一维数组中所有相同的数,使之只剩一个。数组中的数已按由小到大的顺序排列,函数返回删除后数组中数据的个数。 例如,一维数组中的数据是:2 2 2 3 4 4 5 6 6 6 6 7 7 8 9 9 10 10 10
admin
2015-06-08
38
问题
请编写函数fun,函数的功能是:删去一维数组中所有相同的数,使之只剩一个。数组中的数已按由小到大的顺序排列,函数返回删除后数组中数据的个数。
例如,一维数组中的数据是:2 2 2 3 4 4 5 6 6 6 6 7 7 8 9 9 10 10 10。
删除后,数组中的内容应该是:2 3 4 5 6 7 8 9 10。
注意:部分源程序在文件PROGI.C中。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
#include
#define N 8 0
int fun(int a[],int n)
{
}
main()
{ int a[N]={2,2,2,3,4,4,5,6,6,6,6,
7,7,8,9,9,10,10,10,10),i,n=20;void NONO ();
printf(“The original data:\n”);
for(i=0;i
);
n=fun(a,n);
printf(“\n\nThe data after deleted:
\n”);
for(i=0;i
a
);printf(“\n\n”);
NONO();
}
void NONO()
{/*请在此函数内打开文件,输入测试数据,
调用fun函数,输出数据,关闭文件。 */
FILE *rf, *wf; int a[N],n, i, j ;
rf=fopen(“in.dat”,“r”);
wf=fopen(“out.dat”,“w”);
for(i=0;i<5;i++) {
fscarlf(rf,“%d”,&n);
for(j=0;j
“%d”, &a[j]);
n=fun(a, n);
for(j=0;j
(wf,“%4d”,a[j]);
fprintf(wf,“\n”);
}
fclose(rf); fclose(wf);
}
选项
答案
int i,t,j=0,*p=a; t=p[0]; //设置临时变量t初值指向第一数组值 for(i=0;i<=n;i++) if(t==p[i]) //当临时变量与数组中的某个值相同则跳出,比较下一个元素 ; else //如果临时变量与数组中值不同,则对临时变量重新赋值 { a[j]=t; t=p[i]; j++; } if(i>=n) a[j]=t; return j ;
解析
该程序功能是删去一维数组中所有相同的数,使之只剩一个。解题思路是,首先在函数中定义临时变量指向每一个元素,然后在循环过程中将临时值和其他元素进行比较,如果相同,那么跳过相同字符。
[解题思路]
(1)首先,设置一个临时变量,初值设置为一维数组的第一个元素。
(2)然后,依次将数组的元素与临时变量比较,如果相同,则继续取数组下一个元素与临时变量比较;如果不同,则将临时变量的值赋值到数组的第一个元素,同时将此与临时变量不同的数组元素赋值给临时变量。
(3)循环执行,直到所有的数据处理完毕。
转载请注明原文地址:https://kaotiyun.com/show/fiJp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
有以下程序:main(){intaa[4][4]:{{1,2,3,4},{5,6,7,8},{3,9,10,2},{4,2,9,6}};inti,S=0;for(i=0;i<4;i++)s+=aa[i][1];
C语言中各种基本数据类型的存储空间长度排列为()。
实型数据在计算机中表示的方法有()。
执行下面程序的正确结果是()。main(){floata=1.9;switch(a){case0:printf("0000");case1:printf("1111");
设一棵完全二叉树共有500个结点,则在该二叉树中有【】个叶子结点。
下述关于C语言文件的操作的结论中,正确的是______。
在C语言中,函数中变量的隐含存储类别是______。
设血型占2个字节,则unsignedint所能表示的数据范围是______。
以下程序的输出结果是_______。main(){intw=5;fun(w);printf("\n");}fun(intk){if(k>0)fun(k-1);printf("%d",k);
请读程序片段(字符串内没有空格字符):printf("%d\n",strlen("ATS\n012\1\\"));上面程序片段的输出结果是_______。
随机试题
中国共产党的宗旨是
四君子汤治疗脾胃气虚证,若心悸失眠,可加用四君子汤治疗脾胃气虚证,若兼肾阳虚,可加用
钻芯法检测混凝土构件强度,钻取的芯样直径一般不宜小于集料最大粒径的()倍。
一个采用地下连续墙支护的基坑的土层分布情况如图所示:砂土与黏土的天然重度都是20kN/m3。砂层厚10m,黏土隔水层厚1m,在黏土隔水层以下砾石层中有承压水,承压水头8m。没有采用降水措施,为了保证抗突涌的渗透稳定安全系数不小于1.1,该基坑的最大开挖深
必须坚持把发展作为我党执政兴国的<)。
避难走道是指设置防烟设施且两侧采用防火墙分隔,用于人员安全通行至室外的走道。下列关于避难走道防火检查中,符合现行国家工程消防技术标准要求的有()
当事人约定以两种或者两种以上的不同运输方式,采用同一种运输凭证将货物运输至约定地点的运输合同称为( )。
《巴塞尔新资本协议》将市场约束、最低资本要求和外部监管称为资本监管的三大支柱。()
以下关于企业定员管理的说法,不正确的是()。
设总体X的概率密度为其中0<θ<1是未知参数,c是常数.X1,X2,…,Xn为来自总体X的简单随机样本,则c=_____;θ的矩估计量=_____.
最新回复
(
0
)