程序设计10
- 问题10_1
- 代码10_1
- 结果10_1
- 问题10_2
- 代码10_2
- 结果10_2
- 问题10_3
- 代码10_3
- 结果10_3
问题10_1
下列给定程序中已建立一个带结点的单向链表,链表中的各结点数据中的数据递增有序链接,函数 f u n fun fun 的功能是:把形参 x x x 的值放入一个新结点并插入链表中,使插入后各结点数据域中的数据仍保持递增有序。
代码10_1
#include<stdio.h>
#include<stdlib.h>#define N 8typedef struct list{int data;struct list *next;
}SLIST;void fun(SLIST *h, int x){SLIST *p, *q, *s;s = (SLIST *)malloc(sizeof(SLIST));s->data = x;q = h;p = h->next;while(p!=NULL && x>p->data){q = p;p = p->next;}s->next = p;q->next = s;
}SLIST * creatlist(int *a){SLIST *h, *p, *q;int i;h = p = (SLIST *)malloc(sizeof(SLIST));for(i=0; i<N; i++){q = (SLIST *)malloc(sizeof(SLIST));q->data = a[i];p->next = q;p = q;}p->next = 0;return h;
}void outlist(SLIST *h){SLIST *p;p = h->next;if(p==NULL)printf("\nThe list is NULL!\n");else{printf("\nHead");do{printf("->%d", p->data);p = p->next;}while(p!=NULL);printf("->End\n");}
}void main(void){SLIST *head;int x;int a[N] = {11, 12, 15, 18, 19, 22, 25, 29};head = creatlist(a);printf("\nThe list before inserting:\n");outlist(head);printf("\nEnter a number:");scanf("%d", &x);fun(head, x);printf("\nThe list after inserting:\n");outlist(head);
}
结果10_1
问题10_2
函数 f u n fun fun的功能是:计算正整数 n u m num num 各位上的数字之积。
例如,若输入 252 252 252,则输出应该是 20 20 20。若输入 202 202 202,则输出应该是 0 0 0。
代码10_2
#include<stdio.h>
#include<conio.h>long fun(long num){long k = 1;do{k *= num%10;num /= 10;}while(num);return(k);
}main(void){long n;printf("\n Please enter a number:");scanf("%ld", &n);printf("\n%ld\n", fun(n));
}
结果10_2
问题10_3
请编写函数 f u n fun fun ,其功能是:计算 n n n 门课程的平均分,结果作为函数值返回。
例如,若有 5 5 5 门课程的成绩是 : 90.5 , 72 , 80 , 61.5 , 55 :90.5, 72, 80,61.5, 55 :90.5,72,80,61.5,55,则他的平均分应该为 71.80 71.80 71.80。
代码10_3
#include<stdio.h>float fun(float *a, int n){float av = 0.0;int i;for(i=0; i<n; i++)av = av + a[i];return (av/n);
}void main(void){float score[30] = {90.5, 72, 80, 61.5, 55}, aver;aver = fun(score, 5);printf("\nAverage score is:%5.2f\n", aver);
}