您的位置:

c语言sco,c语言scopy

本文目录一览:

c语言中用函数做参数怎么用

数组元素就是下标变量,它与普通变量并无区别。 因此它作为函数实参使用与普通变量是完全相同的,在发生函数调用时,把作为实参的数组元素的值传送给形参,实现单向的值传送。【例5-4】说明了这种情况。

【例8-7】判别一个整数数组中各元素的值,若大于0 则输出该值,若小于等于0则输出0值。编程如下:#include stdio.hvoid nzp(int v){ if(v0) printf("%d ",v); else printf("%d ",0);}int main(void){ int a[5],i; printf("input 5 numbers\n"); for(i=0;i5;i++){ scanf("%d",a[i]); nzp(a[i]); } return 0;}

本程序中首先定义一个无返回值函数nzp,并说明其形参v为整型变量。在函数体中根据v值输出相应的结果。在main函数中用一个for语句输入数组各元素,每输入一个就以该元素作实参调用一次nzp函数,即把a[i]的值传送给形参v,供nzp函数使用。

数组名作为函数参数

用数组名作函数参数与用数组元素作实参有几点不同。

1) 用数组元素作实参时,只要数组类型和函数的形参变量的类型一致,那么作为下标变量的数组元素的类型也和函数形参变量的类型是一致的。因此,并不要求函数的形参也是下标变量。换句话说,对数组元素的处理是按普通变量对待的。用数组名作函数参数时,则要求形参和相对应的实参都必须是类型相同的数组,都必须有明确的数组说明。当形参和实参二者不一致时,即会发生错误。

2) 在普通变量或下标变量作函数参数时,形参变量和实参变量是由编译系统分配的两个不同的内存单元。在函数调用时发生的值传送是把实参变量的值赋予形参变量。在用数组名作函数参数时,不是进行值的传送,即不是把实参数组的每一个元素的值都赋予形参数组的各个元素。因为实际上形参数组并不存在,编译系统不为形参数组分配内存。那么,数据的传送是如何实现的呢?在我们曾介绍过,数组名就是数组的首地址。因此在数组名作函数参数时所进行的传送只是地址的传送,也就是说把实参数组的首地址赋予形参数组名。形参数组名取得该首地址之后,也就等于有了实在的数组。实际上是形参数组和实参数组为同一数组,共同拥有一段内存空间。

上图说明了这种情形。图中设a为实参数组,类型为整型。a占有以2000为首地址的一块内存区。b为形参数组名。当发生函数调用时,进行地址传送,把实参数组a的首地址传送给形参数组名b,于是b也取得该地址2000。于是a,b两数组共同占有以2000为首地址的一段连续内存单元。从图中还可以看出a和b下标相同的元素实际上也占相同的两个内存单元(整型数组每个元素占二字节)。例如a[0]和b[0]都占用2000和2001单元,当然a[0]等于b[0]。类推则有a[i]等于b[i]。

【例8-8】数组a中存放了一个学生5门课程的成绩,求平均成绩。#include stdio.hfloat aver(float a[5]){ int i; float av,s=a[0]; for(i=1;i5;i++) s=s+a[i]; av=s/5; return av;}int main(void){ float sco[5],av; int i; printf("\ninput 5 scores:\n"); for(i=0;i5;i++) scanf("%f",sco[i]); av=aver(sco); printf("average score is %5.2f",av); return 0;}

本程序首先定义了一个实型函数aver,有一个形参为实型数组a,长度为5。在函数aver中,把各元素值相加求出平均值,返回给主函数。主函数main 中首先完成数组sco的输入,然后以sco作为实参调用aver函数,函数返回值送av,最后输出av值。 从运行情况可以看出,程序实现了所要求的功能。

3) 前面已经讨论过,在变量作函数参数时,所进行的值传送是单向的。即只能从实参传向形参,不能从形参传回实参。形参的初值和实参相同,而形参的值发生改变后,实参并不变化,两者的终值是不同的。而当用数组名作函数参数时,情况则不同。由于实际上形参和实参为同一数组,因此当形参数组发生变化时,实参数组也随之变化。当然这种情况不能理解为发生了“双向”的值传递。但从实际情况来看,调用函数之后实参数组的值将由于形参数组值的变化而变化。为了说明这种情况,把【例5.4】改为【例5.6】的形式。

【例8-9】题目同【例8.7】。改用数组名作函数参数。#include stdio.hvoid nzp(int a[5]){ int i; printf("\nvalues of array a are:\n"); for(i=0;i5;i++){ if(a[i]0) a[i]=0; printf("%d ",a[i]); }}int main(void){ int b[5],i; printf("\ninput 5 numbers:\n"); for(i=0;i5;i++) scanf("%d",b[i]); printf("initial values of array b are:\n"); for(i=0;i5;i++) printf("%d ",b[i]); nzp(b); printf("\nlast values of array b are:\n"); for(i=0;i5;i++) printf("%d ",b[i]); return 0;}

本程序中函数nzp的形参为整数组a,长度为5。主函数中实参数组b也为整型,长度也为5。在主函数中首先输入数组b的值,然后输出数组b的初始值。然后以数组名b为实参调用nzp函数。在nzp中,按要求把负值单元清0,并输出形参数组a的值。 返回主函数之后,再次输出数组b的值。从运行结果可以看出,数组b的初值和终值是不同的,数组b的终值和数组a是相同的。这说明实参形参为同一数组,它们的值同时得以改变。

用数组名作为函数参数时还应注意以下几点:

①形参数组和实参数组的类型必须一致,否则将引起错误。

②形参数组和实参数组的长度可以不相同,因为在调用时,只传送首地址而不检查形参数组的长度。当形参数组的长度与实参数组不一致时,虽不至于出现语法错误(编译能通过),但程序执行结果将与实际不符,这是应予以注意的。

【例8.10】如把例8.9修改如下:#include stdio.hvoid nzp(int a[8]){ int i; printf("\nvalues of array aare:\n"); for(i=0;i8;i++){ if(a[i]0)a[i]=0; printf("%d ",a[i]); }}int main(void){ int b[5],i; printf("\ninput 5 numbers:\n"); for(i=0;i5;i++) scanf("%d",b[i]); printf("initial values of array b are:\n"); for(i=0;i5;i++) printf("%d ",b[i]); nzp(b); printf("\nlast values of array b are:\n"); for(i=0;i5;i++) printf("%d ",b[i]); return 0;}

本程序与【例8.9】程序比,nzp函数的形参数组长度改为8,函数体中,for语句的循环条件也改为i8。因此,形参数组a和实参数组b的长度不一致。编译能够通过,但从结果看,数组a的元素a[5]、a[6]、a[7]显然是无意义的。

③在函数形参表中,允许不给出形参数组的长度,或用一个变量来表示数组元素的个数。例如,可以写为:

void nzp(int a[])

或写为

void nzp( int a[], int n )

其中形参数组a没有给出长度,而由n值动态地表示数组的长度。n的值由主调函数的实参进行传送。由此,【例8-10】又可改为【例8-11】的形式。

【例8-11】复制纯文本新窗口

#include stdio.hvoid nzp(int a[],int n){ int i; printf("\nvalues of array a are:\n"); for(i=0;in;i++){ if(a[i]0) a[i]=0; printf("%d ",a[i]); }}int main(void){ int b[5],i; printf("\ninput 5 numbers:\n"); for(i=0;i5;i++) scanf("%d",b[i]); printf("initial values of array b are:\n"); for(i=0;i5;i++) printf("%d ",b[i]); nzp(b,5); printf("\nlast values of array b are:\n"); for(i=0;i5;i++) printf("%d ",b[i]); return 0;}

关于c语言文件查找

//读数

#includestdio.h

#includestdlib.h

#define N 20

struct stud

int num;

int sco1;

int sco2;

int sco3;

}stu[N];

void main()

FILE *fp;

double ave;

int i=0,x;

if((fp=fopen("STUDENT.DAT","r"))==NULL)

printf("无法打开该文件!\n");

exit(0); 

}

else 

printf("文件打开成功!\n");

for(i=0;iN;i++){

fread(stu[i],sizeof(struct stud),1,fp);

i++;    

}

fclose(fp);

printf("请输入要查找的学生学号:\n");

scanf("%d",x);

for(i=0;iN;i++)

if(x==stu[i].num) 

ave=(double)(stu[i].sco1+stu[i].sco2+stu[i].sco3)/3.0;

break;

}

else 

i++;

}

if(i==10||ave0||ave100)  

printf("查无该生成绩!\n");

else 

printf("该生平均成绩为:%.2lf\n",ave);

}

//存数

#includestdio.h

#includestdlib.h

#define N 20

struct stud

int num;

int sco1;

int sco2;

int sco3;

}stu[N];

void main()

{

FILE *fp;

int i,n;

float sum1=0,sum2=0,sum3=0,ave1=0,ave2=0,ave3=0;

if((fp=fopen("STUDENT.DAT","wb"))==NULL)

printf("无法打开该文件!\n");

exit(0);

}

else 

printf("文件打开成功!\n");

printf("请输入要输入的学生数:\n");

scanf("%d",n);

for(i=0;in;i++)

printf("请输入学生学号,数学成绩,政治成绩和英语成绩:\n");

scanf("%d%d%d%d/n",stu[i].num,stu[i].sco1,stu[i].sco2,stu[i].sco3);

sum1+=stu[i].sco1;

sum2+=stu[i].sco2;

sum3+=stu[i].sco3;

if(fwrite(stu[i],sizeof(struct stud),1,fp)!=1)

printf("file write error\n");

}

fclose(fp);

ave1=sum1/n;

ave2=sum2/n;

ave3=sum3/n;

printf("------------------------------------\n");

printf("NUM   Math   Prolitics   English\n");

for(i=0;in;i++)

printf("%d%7d%10d%14d\n",stu[i].num,stu[i].sco1,stu[i].sco2,stu[i].sco3);

}

printf("------------------------------------\n");

printf("对应三门成绩均分为:\n");

printf(" %7.2f%10.2f%14.2f\n",ave1,ave2,ave3);

}

C语言中sco是什么意思?求解,有分哦~~~

你这sco是定义的一个数组

同下

int array[10];

while(i10)

{

scanf("%d",array[i]);

}

C语言编写的程序:十个学生的五门成绩的各科平均值

#include

/*定义结构体*/

struct

student

{

int

a;

int

b;

int

c;

float

ave;

};

int

main()

{

struct

student

sco[5];

printf("输入5个学生的3们成绩:\n");

for(i=0;i5;i++)

{

scanf("%d%d%d",sco[i].a,sco[i].b,sco[i].c);

sco[i].ave=(float)(sco[i].a+sco[i].b+sco[i].c)/3;

}

printf("5名学生平均成绩分别为:\n");

for(i=0;i5;i++)

{

printf("%.2f\n",sco[i].ave);

}

return

0;

}

————————————————

如果以上出现“%”符号,那是为何防止系统误识我把半角符号写成全角符号了,注意改回来。

————————————————

亲爱的lz,如果我的回答能够帮你解决问题,或是对你有帮助,或是对你今后的发展造成积极的影响,那么请您采纳我的回答吧,同时更迫切地希望您能够在采纳的时候帮我打上“能解决”和“原创”,然后把两行的五颗五角星分别点亮,点亮五角星就是点亮你我的希望。

我冲11级了,需要很多综合声望,感谢您的帮助,衷心祝愿您快乐每一天~

c语言编程

第一题核心是排序,我先用冒泡排序来实现吧。

#include stdio.h

#define LEN 30 /*学生人数*/

void bubbleSort(int arr[], int len) { /*由大到小冒泡排序*/

int i, j, temp;

for (i = 0; i  len - 1; i++)

for (j = 0; j  len - 1 - i; j++)

if (arr[j]  arr[j + 1]) {

temp = arr[j];

arr[j] = arr[j + 1];

arr[j + 1] = temp;

}

}

int main()

{

int i;

int sco[LEN] = {70,99,87,65,59,98,85,73,65,59,62,70,80,92,54,35,90,87,37,66,80,33,45,62,68,48,76,56,78,90};

float sum=0,aver=0;

printf ("原始30名学生成绩:\n");

for (i=0;iLEN;i++) {

printf ("%d\t",sco[i]);

}

printf ("======================================================\n\n");

bubbleSort (sco,LEN); 

printf ("30名学生成绩由高到低排序:\n");

for (i=0;iLEN;i++) {

printf ("%d\t",sco[i]);

sum +=  sco[i];

}

printf ("======================================================\n\n");

aver = sum/LEN;

printf ("高于平均分%.2f的学生成绩:\n",aver);

for (i=0;iLEN;i++) {

if (sco[i]aver) {

printf ("%d\t",sco[i]);

}

}

printf ("\n");

    return 0;

}

运行结果

第二题没太看懂,具体要求是啥,感觉就是考察函数调用,我先随便写个简答的吧。

#include stdio.h

int x (int y) { /*输入y,返回y平方*/

return y*y; 

}

int main()

{

int y;

printf ("请输入y:");

scanf ("%d",y);

printf ("\n");

y = x(y);

printf ("调用x函数求y平方:%d\n",y);

printf ("\n");

    return 0;

}

运行结果