12课后

作业1:
通过输入两个加数,给学生出一道加法运算题。如果输入答案正确,则显示“Y”;否则显示“N”。
要求:程序循环执行n次,用函数实现判断对错和输出结果
输入输出示例:(括号内部分是对输入输出的解释,不要出现在程序中)
示例一:
1,2(输入)
1+2=4(1+2=由程序输出,4由键盘输入)
N. (由程序输出)
示例二:
1,2(输入)
1+2=3(1+2=由程序输出,3由键盘输入)
Y(由程序输出).
  1. #include <stdio.h>   
  2. int isright();  
  3. void main()  
  4. {  
  5.     while(1)  
  6.     {  
  7.         if(isright())  
  8.             printf("Y\n");  
  9.         else  
  10.         printf("N\n");  
  11.   
  12.     }  
  13. }  
  14. int isright()  
  15. {  
  16. int a,b,sum;  
  17. printf("请输入两个数.\n");  
  18. scanf_s("%d%d",&a,&b);  
  19. printf("%d+%d=",a,b);  
  20. scanf_s("%d",&sum);  
  21. if(sum==a+b)  
  22.     return 1;  
  23. else  
  24. return 0;  
  25. }  
#include <stdio.h>
int isright();
void main()
{
	while(1)
	{
		if(isright())
			printf("Y\n");
		else
		printf("N\n");

	}
}
int isright()
{
int a,b,sum;
printf("请输入两个数.\n");
scanf_s("%d%d",&a,&b);
printf("%d+%d=",a,b);
scanf_s("%d",&sum);
if(sum==a+b)
	return 1;
else
return 0;
}


 


-----------------------分割线-----------------------
作业2:
统计和分析某班学生考试成绩,实现如下学生成绩管理功能:
(1)录入每个学生的学号和考试成绩;
(2)计算课程的平均分;
(3)按成绩由高到低排出名次表;
(4)按学号查询学生排名及其考试成绩;
(5)按优秀(90~100)、不及格(0~59)2个类别,统计每个类别的人数及其所占的百分比;
要求:最多不超过40人(具体人数由键盘输入)参加某门课程的考试,用一维数组作函数参数编程

输入输出示例:

  1. #include <stdio.h>   
  2. #define maxnum 40   
  3. void sort(int student[maxnum][2],int num);  
  4. void search(int student[maxnum][2],int num,int stuID);  
  5. void main()  
  6. {  
  7.     int num,sum=0,i,stuID=0,stuScore=0;  
  8.     printf("请输入学生数量:\n");  
  9.     scanf_s("%d",&num);  
  10.     printf("请输入学号和分数:\n");  
  11.     int student[maxnum][2];  
  12.     for(i=0;i<num;i++)  
  13.     {  
  14.         scanf_s("%d,%d",&stuID,&stuScore);  
  15.         student[i][0]=stuID;  
  16.         student[i][1]=stuScore;  
  17.     }  
  18.     for(i=0;i<num;i++)//求总成绩   
  19.     {  
  20.         sum+=student[i][1];  
  21.     }  
  22.     printf("平均分是:%d\n",sum/num);  
  23.   
  24.     printf("成绩名次表:\n");  
  25.     sort(student,num);  
  26.   
  27.     printf("请输入你想查询的学生学号:\n");  
  28.     scanf_s("%d",&stuID);  
  29.     search(student,num,stuID );  
  30.   
  31.     printf("优秀\t\t不及格\n");  
  32.     float goodnum=0.0,badnum=0.0;  
  33.     for(i=0;i<num;i++)  
  34.     {  
  35.     if(student[i][1]<=100&&student[i][1]>=90)  
  36.     {  
  37.     goodnum++;  
  38.     }  
  39.     else if(student[i][1]<=59&&student[i][1]>=0)  
  40.     {  
  41.     badnum++;  
  42.     }  
  43.     }  
  44.     printf("%.0f  \t\t%.0f\n",goodnum,badnum);  
  45.     printf("%.2f%%  \t%.2f%%\n",goodnum/num*100,badnum/num*100);  
  46. }  
  47.   
  48. void sort(int student[maxnum][2],int num)//冒泡排序   
  49. {  
  50.     int temp1,temp2,i,j;  
  51.     for(i=0;i<num;i++)  
  52.     {  
  53.         for(j=0;j<num;j++)  
  54.         {  
  55.             if(student[j][1]<student[j+1][1])  
  56.             {  
  57.                 //学号交换   
  58.                 temp1=student[j][0];  
  59.                 student[j][0]=student[j+1][0];  
  60.                 student[j+1][0]=temp1;  
  61.                 //成绩交换   
  62.                 temp2=student[j][1];  
  63.                 student[j][1]=student[j+1][1];  
  64.                 student[j+1][1]=temp2;  
  65.             }  
  66.         }  
  67.     }  
  68.     for(i=0;i<num;i++)  
  69.     {  
  70.         printf("%d\t%d\n",student[i][0],student[i][1]);  
  71.     }  
  72. }  
  73. void search(int student[maxnum][2],int num,int stuID)//查询   
  74. {  
  75.     for(int i=0;i<num;i++)  
  76.     {  
  77.         if(stuID==student[i][0])  
  78.         {  
  79.             printf("学号:%d  名次%d ,其考试成绩:%d\n",student[i][0],i+1,student[i][1]);  
  80.         }  
  81.     }  
  82. }  
#include <stdio.h>
#define maxnum 40
void sort(int student[maxnum][2],int num);
void search(int student[maxnum][2],int num,int stuID);
void main()
{
	int num,sum=0,i,stuID=0,stuScore=0;
	printf("请输入学生数量:\n");
	scanf_s("%d",&num);
	printf("请输入学号和分数:\n");
	int student[maxnum][2];
	for(i=0;i<num;i++)
	{
		scanf_s("%d,%d",&stuID,&stuScore);
		student[i][0]=stuID;
		student[i][1]=stuScore;
	}
	for(i=0;i<num;i++)//求总成绩
	{
		sum+=student[i][1];
	}
	printf("平均分是:%d\n",sum/num);

	printf("成绩名次表:\n");
	sort(student,num);

	printf("请输入你想查询的学生学号:\n");
	scanf_s("%d",&stuID);
	search(student,num,stuID );

	printf("优秀\t\t不及格\n");
	float goodnum=0.0,badnum=0.0;
	for(i=0;i<num;i++)
	{
	if(student[i][1]<=100&&student[i][1]>=90)
	{
	goodnum++;
	}
	else if(student[i][1]<=59&&student[i][1]>=0)
	{
	badnum++;
	}
	}
	printf("%.0f  \t\t%.0f\n",goodnum,badnum);
	printf("%.2f%%  \t%.2f%%\n",goodnum/num*100,badnum/num*100);
}

void sort(int student[maxnum][2],int num)//冒泡排序
{
	int temp1,temp2,i,j;
	for(i=0;i<num;i++)
	{
		for(j=0;j<num;j++)
		{
			if(student[j][1]<student[j+1][1])
			{
				//学号交换
				temp1=student[j][0];
				student[j][0]=student[j+1][0];
				student[j+1][0]=temp1;
				//成绩交换
				temp2=student[j][1];
				student[j][1]=student[j+1][1];
				student[j+1][1]=temp2;
			}
		}
	}
	for(i=0;i<num;i++)
	{
		printf("%d\t%d\n",student[i][0],student[i][1]);
	}
}
void search(int student[maxnum][2],int num,int stuID)//查询
{
	for(int i=0;i<num;i++)
	{
		if(stuID==student[i][0])
		{
			printf("学号:%d  名次%d ,其考试成绩:%d\n",student[i][0],i+1,student[i][1]);
		}
	}
}


 

 


-----------------------分割线-----------------------

作业3:用指针(间接引用)求出两个数中的最大数.

  1. #include <stdio.h>   
  2. void main()  
  3. {  
  4.     int a,b;  
  5.     int *pointer_1=&a,*pointer_2=&b;  
  6.     printf("please input 2 num:\n");  
  7.     scanf("%d,%d",&a,&b);  
  8.     if(a>b)  
  9.     {  
  10.         printf("The big num is:%d\n",*pointer_1);  
  11.     }  
  12.         printf("The big num is:%d\n",*pointer_2);  
  13. }  
#include <stdio.h>
void main()
{
	int a,b;
	int *pointer_1=&a,*pointer_2=&b;
	printf("please input 2 num:\n");
	scanf("%d,%d",&a,&b);
	if(a>b)
	{
		printf("The big num is:%d\n",*pointer_1);
	}
		printf("The big num is:%d\n",*pointer_2);
}


 

 


-----------------------分割线-----------------------

作业4:编写交换两个变量值的函数,并交换主函数中两个变量的值(不能使用全局变量传递数据).
  1. #include <stdio.h>   
  2. void swap(int *a,int*b)  
  3. {  
  4.     int temp;  
  5.     temp =*a;  
  6.     *a=*b;  
  7.     *b=temp;  
  8. }  
  9. void main()  
  10. {  
  11.     int a,b;  
  12.     int *p1,*p2;  
  13.     printf("请输入两个数:");  
  14.     scanf_s("%d,%d",&a,&b);  
  15.     printf("交换前:");  
  16.     printf("%d\t%d\n",a,b);  
  17.     p1=&a;  
  18.     p2=&b;  
  19.     swap(p1,p2);  
  20.     printf("交换后:");  
  21.     printf("%d\t%d",a,b);  
  22.     getchar();  
  23.         getchar();  
  24. }  
#include <stdio.h>
void swap(int *a,int*b)
{
	int temp;
	temp =*a;
	*a=*b;
	*b=temp;
}
void main()
{
	int a,b;
	int *p1,*p2;
	printf("请输入两个数:");
	scanf_s("%d,%d",&a,&b);
	printf("交换前:");
	printf("%d\t%d\n",a,b);
	p1=&a;
	p2=&b;
	swap(p1,p2);
	printf("交换后:");
	printf("%d\t%d",a,b);
	getchar();
		getchar();
}


 

 


-----------------------分割线-----------------------
作业5:从键盘输入5个整数存入一维数组中,再按反序输出(要求用指针访问数组元素).
  1. #include<stdio.h>   
  2. #define num 5   
  3. void main()  
  4. {  
  5.     int i,*p;  
  6.     int number[num];  
  7.     printf("请输入五个数:\n");  
  8.     for(i=0;i<num;i++)  
  9.     {  
  10.     scanf("%d",&number[i]);  
  11.     }  
  12.     printf("这五个数的逆序是:\n");  
  13.     for(p=number+num-1;p>=number;p--)  
  14.     {  
  15.     printf("%d\n",*p);  
  16.     }  
  17. }  
#include<stdio.h>
#define num 5
void main()
{
	int i,*p;
	int number[num];
	printf("请输入五个数:\n");
	for(i=0;i<num;i++)
	{
	scanf("%d",&number[i]);
	}
	printf("这五个数的逆序是:\n");
	for(p=number+num-1;p>=number;p--)
	{
	printf("%d\n",*p);
	}
}


 

 

 


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值