当前位置:首页>维修大全>综合>

c语言100行简单一点的代码

c语言100行简单一点的代码

更新时间:2023-09-22 13:59:09

c语言100行简单一点的代码

#include <malloc.h>

#include <stdio.h>

#include <stdlib.h>

#define LEN sizeof(struct scorenode)

#define DEBUG

#include <string.h>

struct scorenode

{int number;/*学号*/

char name[10];/*姓名*/

float yuwen;/*语文成绩*/

float yingyu;/*英语成绩*/

float shuxue;/*数学成绩 */

struct scorenode *next;

};

typedef struct scorenode score;

int n,k;/*n,k为全局变量,本程序中的函数均可以使用它*/

/*==============================================================================================*/

score *creat2311(void)

/*函数creat2311,功能:创建链表,此函数带回一个指向链表头的指针*/

{

score*head;

score *p1,*p2,*p3,*max;

int i,j;

float fen;

char t[10];

n=0;

p1=p2=p3=(score *)malloc(LEN);head=p3; /*开辟一个新单元*/

printf("请输入学生资料,输0退出! ");

repeat1: printf("请输入学生学号(学号应大于0):");/*输入学号,学号应大于0*/

scanf("%d",&p1->number);

while(p1->number<0)

{getchar();

printf("输入错误,请重新输入学生学号:");

scanf("%d",&p1->number);}

/*输入学号为字符或小于0时,程序报错,提示重新输入学号*/

if(p1->number==0)

goto end;/*当输入的学号为0时,转到末尾,结束创建链表*/

else

{

p3=head;

if(n>0)

{for(i=0;i<n;i++)

{if(p1->number!=p3->number)

p3=p3->next;

else

{printf("学号重复,请重输! ");

goto repeat1;

/*当输入的学号已经存在,程序报错,返回前面重新输入*/

}

}

}

}

printf("请输入学生姓名:");

scanf("%s",&p1->name);/*输入学生姓名*/

printf("请输入语文成绩(0~100):");/*输入语文成绩,成绩应在0-100*/

scanf("%f",&p1->yuwen);

while(p1->yuwen<0||p1->yuwen>100)

{getchar();

printf("输入错误,请重新输入语文成绩");/*输入错误,重新输入语文成绩直到正确为止*/

scanf("%f",&p1->yuwen);}

printf("请输入英语成绩(0~100):");/*输入英语成绩,成绩应在0-100*/

scanf("%f",&p1->yingyu);

while(p1->yingyu<0||p1->yingyu>100)

{getchar();

printf("输入错误,请重新输入英语成绩");/*输入错误,重新输入英语成绩直到正确为止*/

scanf("%f",&p1->yingyu);}

printf("请输入数学成绩(0~100):");/*输入数学成绩,成绩应在0-100*/

scanf("%f",&p1->shuxue);

while(p1->shuxue<0||p1->shuxue>100)

{getchar();

printf("输入错误,请重新输入数学成绩");

scanf("%f",&p1->shuxue);}/*输入错误,重新输入数学成绩直到正确为止*/

p1=head;

p0=stu;

if(head==NULL)

{head=p0;p0->next=NULL;}/*当原来链表为空时,从首结点开始存放资料*/

else/*原来链表不为空*/

{

if(p1->next==NULL)/*找到原来链表的末尾*/

{

p1->next=p0;

p0->next=NULL;/*将它与新开单元相连接*/

}

else

{

while(p1->next!=NULL)/*还没找到末尾,继续找*/

{

p2=p1;p1=p1->next;

}

p1->next=p0;

p0->next=NULL;

}

}

n=n+1;

p1=head;

p0=stu;

for(i=1;i<n;i++)

{

for(j=i+1;j<=n;j++)

{

max=p1;

p1=p1->next;

if(max->number>p1->number)

{

k=max->number;

max->number=p1->number;

p1->number=k;

/*交换前后结点中的学号值,使得学号大者移到后面的结点中*/

strcpy(t,max->name);

strcpy(max->name,p1->name);

strcpy(p1->name,t);

/*交换前后结点中的姓名,使之与学号相匹配*/

fen=max->yuwen;

max->yuwen=p1->yuwen;

p1->yuwen=fen;

/*交换前后结点中的语文成绩,使之与学号相匹配*/

fen=max->yingyu;

max->yingyu=p1->yingyu;

p1->yingyu=fen;

/*交换前后结点中的英语成绩,使之与学号相匹配*/

fen=max->shuxue;

max->shuxue=p1->shuxue;

p1->shuxue=fen;

/*交换前后结点中的数学成绩,使之与学号相匹配*/

}

}

max=head;p1=head;/*重新使max,p指向链表头*/

} end2:

printf("现在的学生数为:%d个! ",n);

return(head);

}

/*==============================================================================================*/

/*==============================================================================================*/

score *search2311(score *head)

/*函数search2311,功能:查询学生成绩*/

{int number;

score *p1,*p2;

printf("输入要查询的学生的学号,");

scanf("%d",&number);

while(number!=0)

{

if(head==NULL)

{printf(" 没有任何学生资料! ");return(head);}

printf("----------------------------------------- ");

printf("|学号 |姓名 |语文 |英语 |数学 | ");

printf("----------------------------------------- ");/*打印表格域*/

p1=head;

while(number!=p1->number&&p1->next!=NULL)

{p2=p1;p1=p1->next;}

if(number==p1->number)

{printf("|%d |%s |%.1f |%.1f |%.1f | ",p1->number,p1->name,p1->yuwen,p1->yingyu,p1->shuxue);

printf("----------------------------------------- ");}/*打印表格域*/

else

printf("%d不存在此学生! ",number);

printf("输入要查询的学生的学号,");

scanf("%d",&number);

}

printf("已经退出了! ");

return(head);}

更多栏目