首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请编写函数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
2017-11-27
44
问题
请编写函数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。
注意:部分源程序在文件PROG1.C中。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
#include
#define N 80
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
a
);
n=fun(a,n);
printf("\n\nThe data after deleted:
\n");
for(i=0;i
printf("%3d",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++) {
fscanf(rf, "%d", &n);
for(j = 0 ; j < n ; j++)
fscanf(rf, "%d", &a[j]);
n = fun (a, n);
for(j = 0 ; j < n ; j++)
fprintf (wf, "%4d", a[j]);
fprintf(wf, "\n");
}
f close (rf); f close (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://jikaoti.com/ti/25a0FFFM
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
当运行以下程序时,输入abcd,程序的输出结果是:()。insert(charstr[]){inti;i=strlen(str);while(i>0){str[2*i]=str[i];str[2*i-1
以下程序运行后的输出结果是()。voidswap(intX,inty){intt;t=x;x=y;y=t;printf("%d%d",x,y);}main(){inta=3,b=
以下程序运行后的输出结果是()。main(){intx=0210;printf("%x\n",x);}
数据库系统的核心是()。
若k是int类型变量,且有以下for语句foroc=-1;k
以下选项中,能表示逻辑值“假”的是
下列叙述中正确的足
下面关于数据库三级模式结构的叙述中,正确的是()。
下列程序的功能是:求出ss所指字符串中指定字符的个数,并返回此值。例如,若输入字符串123412132,输入字符1,则输出3,请填空。#include#include#defineM81inttim(
以下有4组用户标识符,其中合法的一组是()。
随机试题
枕左前位胎头入盆衔接时的径线是
患者男27岁,具有剧烈自发性搏动性牙痛,遇冷刺激可暂时缓解临床诊断可能是
关于三因治宜的叙述错误的为
夏季,某湖中藻类大量繁殖,形成水华,鱼类大量死亡,水有异味。需调查及治理的污染源是
下列不属于禁止外商投资产业目录中的项目的是()。
甲公司原材料采用计划成本核算,月初“原材料”科目借方余额35000元,本月购入原材料的计划成本为200000元,本月发出原材料的计划成本为150000元,“材料成本差异”科目月初贷方余额480元,本月购入材料的超支差为5180元,则本月结存材料的实际成
集“窄、长、奇、秀、险”为一体的国家级森林公园是()。
班杜拉的自我功效论认为,自我效能感是建立在下列哪些信息上的?()
Theprototypingmethodisadynamicdesignprocess,whichrequirespeoplewhouseprototypingmethodtohavethefollowingcapabi
首先访问该结点,然后访问结点的左子树,最后访问结点的右子树,这种遍历方式称为( )。
最新回复
(
0
)