作业八代码
1.输入10个学生的分数,输出其总分和平均分。要求用数组实现。
#include<stdio.h> int main() { int i; float sum,average,score[10]; printf("请输入10个学生的成绩:"); for(i=0;i<=10;i++) { scanf("%f",&score[i]); sum=sum+score[i]; average=sum/10; } printf("sum=%f\n",sum); printf("average=%f\n",average); return 0; }
2.顺序查找法。输入5个整数,将它们存入数组a中,再输入一个数x,然后在数组中查找x,如果找到,输出相应的最小下标,否则,输出"Not Found"。
#include<stdio.h> int main() { int i,x,flag,a[10]; printf("请输入5个整数:"); for(i=0;i<=5;i++) scanf("%d",&a[i]); printf("请输入x:"); scanf("%d",x); flag=0; for(i=0;i<=5;i++) if(x==a[i]) { printf("Index is %d\n"); flag=1; break; } if(flag==0) printf("Not Found\n"); return 0; }
3.求最大值及其下标。输入一个正整数n(1<n≤10), 再输入n个整数, 输出最大值和它所对应的下标。
#include<stdio.h> int main(void) { int i,index,n; int a[10]; printf("enter n:"); scanf("%d",&n); printf("enter %d integers:",n); for(i=0;i<n;i++) scanf("%d",&a[i]); index=0; for(i=0;i<n;i++) if(a[i]>a[index]) index=i; printf("max is %d \tsub is %d \n",a[index],index); return 0; }
4.输入一个正整数n (1<n≤10),再输入n个整数,用选择法将它们从大到小排序后输出。
#include<stdio.h> int main() { int i,index,k,n,temp; int a[10]; printf("Enter n:"); scanf("%d",&n); printf("Enter %d integers:",n); for(i=0;i<n;i++) scanf("%d",&a[i]); for(k=0;k<n-1;k++) { index=k; for(i=k+1;i<n;i++) if(a[i]>a[index]) index=i; temp=a[index]; a[index]=a[k]; a[k]=temp; } printf("After sorted:"); for(i=0;i<n;i++) printf("%d",a[i]); printf("\n"); return 0; }
5.找出不是两个数组共有的元素。输入一个正整数n(1<n≤10),再输入n个整数,存入第一个数组中;然后输入一个正整数m(1<m≤10),再输入m个整数,存入第二个数组中,找出所有不是这两个数组共有的元素。
include<stdio.h> int main() { int m,n,x,y,a[100],b[100]; printf("输入第一组数字个数:"); scanf("%d",&n); printf("输入n个数:"); int i,j; for(i=1;i<=n;i++) { scanf("%d",&x); a[i]=x; } printf("输入第二组数字个数:"); scanf("%d",&m); printf("输入n个数:"); for(i=1;i<=m;i++) { scanf("%d",&y); b[i]=y; } printf("共有的数:"); for(i=1;i<=n;i++) { for(j=1;j<=m;j++) { if(a[i]==b[j]) printf("%d",a[i]); } } return 0; }