51.写一函数建立一个有3名学生数据的单向动态链表。
52.设有若干个人员的数据,其中有学生和教师。学生的数据中包括:姓名、号码、性别、职业、班级。教师的数据包括:姓名、号码、性别、职业、职务。现要求把它们放在同一表格中
53.口袋中有红、黄、蓝、白、黑5种颜色的球若干个。每次从口袋中先后取出3个球,问得到3种不同色的球的可能取法,打印出每种排列的情况。
- 输入a,b,c3个整数,按从大到小输出(指针)
55.将数组a中n个整数按相反顺序存放。思路:数组元素头尾对调。四种调用方式。
实参与形参均用数组
实参用数组,形参用指针变量
实参与形参均用指针变量
实参用指针变量,形参用数组
56.从10个数中找出其中最大值和最小值为了得到两个结果值,用两个全局变量max和min。
实参和形参均用数组
实参和形参均用指针变量
57.3个学生各学4门课,计算总平均分,输出第n个学生成绩。
58.13个学生各学4门课,计算总平均分,并查找一门以上课程不及格学生, 输出其各门课成绩。
59.用函数指针变量作参数,求最大值、最小值和两数之和
60.有若干学生成绩,要求输入学生序号后,能输出该学生全部成绩。用指针函数实现。
51.
#include<stdio.h>
#include<stdlib.h>
#define LEN sizeof(struct student)
struct student
{
int num;
char name[100];
struct student *next;
};
int n;
struct student *scan(void)
{
struct student *p1,*p2,*head;
p1=p2=(struct student *)malloc(LEN);
scanf("%d%s",&p1->num,p1->name);
while(p1->num!=0)
{
}
void print( struct student *head)
{
struct student *p;
printf("\n Now, these %d records are :\n", n);
p=head;
if((head)!=NULL)
do
{
printf("%d,%s\n", p->num, p->name);
p=p->next;
}
while(p !=NULL);
}
main()
{
print(scan());
}
52.不会
53.
#include<stdio.h>
main()
{
int i,j,k,n=0;
for(i=0;i<5;i++)
for(j=i+1;j<5;j++)
{
for(k=j+1;k<5;k++)
{
n++;
printf("%d,%d,%d ",i,j,k);
}
}
printf("%d",n);
}
54.
#include<stdio.h>
swap(int *a,int *b)
{
int n;
n=*a;*a=*b;*b=n;
}
main()
{
int a,b,c,*p1,*p2,*p3;
scanf("%d%d%d",&a,&b,&c);
p1=&a;p2=&b;p3=&c;
if(*p1<*p2)
swap(p1,p2);
if(*p1<*p3)
swap(p1,p3);
if(*p2<*p3)
swap(p2,p3);
printf("%d%d%d",*p1,*p2,*p3);
}
55.不会
56.
#include<Stdio.h>
int max,min;
fun1(int a[10])
{
max=a[0];
int i;
for(i=0;i<10;i++)
if(max<a[i])
max=a[i];
}
fun2(int *a)
{
min=a[0];
int i;
for(i=0;i<10;i++)
if(min>a[i])
min=a[i];
}
main()
{
int i,a[10];
for(i=0;i<10;i++)
scanf("%d",&a[i]);
fun1(a);
fun2(a);
printf("max=%d min=%d",max,min);
}
57.
#include<stdio.h>
struct student
{
char name[100];
int change[4];
}a[3];
float fun(struct student a[3])
{
int i,j;float sum=0;
for(i=0;i<3;i++)
for(j=0;j<4;j++)
sum+=a[i].change[j];
return(sum/12);
}
main()
{
int i,j;
for(i=0;i<3;i++)
{
scanf("%s",a[i].name);
for(j=0;j<4;j++)
{
scanf("%d",&a[i].change[j]);
}
}
printf("%f",fun(a));
}
58.
#include<stdio.h>
struct student
{
char name[100];
int change[4];
}a[13];
float fun(struct student a[13])
{
int i,j,n;
for(i=0;i<13;i++)
{
n=0;
for(j=0;j<4;j++)
{
if(a[i].change[j]<60)
n++;
}
if(n>=2)
{
printf("%s ",a[i].name);
for(j=0;j<4;j++)
printf("%d ",a[i].change[j]);
printf("\n");
}
}
}
main()
{
int i,j;
for(i=0;i<13;i++)
{
scanf("%s",a[i].name);
for(j=0;j<4;j++)
{
scanf("%d",&a[i].change[j]);
}
}
fun(a);
}
59.
#include<stdio.h>
fun(int *max,int *min,int *sum,int a[10])
{
*max=*min=a[0];
int i;
for(i=0;i<10;i++)
{
if(a[i]>*max)
*max=a[i];
if(a[i]<*min)
*min=a[i];
}
*sum=*max+*min;
}
main()
{
int a[10],max,min,sum,i;
for(i=0;i<10;i++)
{
scanf("%d",&a[i]);
}
fun(&max,&min,&sum,a);
printf("max=%d,min=%d,sum=%d",max,min,sum);
}
60.
#include <stdio.h>
float *search(float (*p1)[4],int n)
{
float *pt;
pt=*(p1+n);
return pt;
}
int main(void)
{
float score[][4]={{60,70,80,90},{56,89,67,88},{34,78,90,66}};
float *p;
int i,k;
printf("输入要找的学生号:\n");
scanf("%d",&k);
printf("第%d个学生的全部成绩为:\n",k);
p=search(score,k);
for(i=0;i<4;i++)
{
printf("%f\t",*(p+i));
}
printf("\n");
return 0;
}