2021-08-04

51.写一函数建立一个有3名学生数据的单向动态链表。

52.设有若干个人员的数据,其中有学生和教师。学生的数据中包括:姓名、号码、性别、职业、班级。教师的数据包括:姓名、号码、性别、职业、职务。现要求把它们放在同一表格中

53.口袋中有红、黄、蓝、白、黑5种颜色的球若干个。每次从口袋中先后取出3个球,问得到3种不同色的球的可能取法,打印出每种排列的情况。

  1. 输入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;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值