当前位置:首页 » 考试成绩 » 排序链表学生成绩

排序链表学生成绩

发布时间: 2021-01-31 11:57:14

㈠ 设计一程序将文件中的学生信息读出,按先后顺序建立链表,并对链表中的学生记录按总分降序排序,要排名。

其他的都给你写出来了 排序很简单的 你自己就可以写 我没有时间给你写了
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
typedef struct student
{char num[6];
char name[8];
int tax; /*名次*/
int english;
int math;
int score;
struct student *next;
}STUDENT;
STUDENT *head = NULL,*tel=NULL;
void Score_Sort();//排序
void Student_Information_show();//显示所有学生信息
void Stident_Read_from_File();
void Student_Add(STUDENT stu);

void Score_Sort()
{
}
void Student_Information_show()
{
STUDENT *temp;
temp=head;
for(temp;temp!=NULL;temp=temp->next)
{
printf("%s %s %d %d %d \n",temp->num,temp->name,temp->english,temp->math,temp->score);
}
}
void Stident_Read_from_File()
{
FILE *file1;
char str[255];
char num[6],name[8];
int english, math;
STUDENT STU;
file1=fopen("Student.txt","r+");
if(file1!=NULL)
{
while((fgets(str,255,file1))!=NULL)
{
sscanf(str,"%s %s %d %d",num,name,&english,&math);
strcpy(STU.num,num);
strcpy(STU.name,name);
STU.english=english;
STU.math=math;
STU.score=english+math;
STU.tax=0;
Student_Add(STU);
}
}

}
void Student_Add(STUDENT stu)
{
STUDENT *temp;//创建一个新的节点并申请空间
temp=(STUDENT *)malloc(sizeof(STUDENT));
strcpy(temp->num,stu.num);
strcpy(temp->name,stu.name);
temp->english=stu.english;
temp->math=stu.math;
temp->tax=stu.tax;
temp->score=stu.score;
temp->next =NULL;
if(head==NULL)
{
head=temp;
}
else
{
tel->next = temp;
}
tel=temp;
}
int main()
{
Stident_Read_from_File();
Student_Information_show();
return 0;
}

㈡ 数据结构实验:运用顺序表或链表,实现对学生成绩的输入、输出、查询、插入、删除、修改、排序等功能

这个问题你可以用易微库表这个工具试下,工具可以在网络软件http://rj..com/中搜索易微库表,使用手册可以在网络文库http://wenku..com/中搜索易微库表,以下是简介
普通人也可以自己设计程序,根据平时处理业务数据时总结的表格、方法、公式等信息,创建一个自己的程序。数据结构自定义、自动计算记录数、自动计算列合计、录入首字母自动显示相应的属性类值、Excel数据处理、数据去重、数据整理、数据统计、数据一维表变成二维表的列转行,数据公式计算、数据首字母检索、数据快速检索、Excel数据导入、Excel数据导出、数据显示排序、查询结果计算百分比、查询结果计算顺序名次、数据查询条件自定义、数据高级筛选、小数据量数据挖掘、自定义显示字段名称等等这些功能都可以通过简单配置后即可实现。如此神奇的事情,赶快创建一个属于自己的库表程序吧。

㈢ 如何找出链表学生成绩前十名 算法

这样做理论上并没有改变原链表的特性,但是少了一些结点。 第二,在删除重复数节点内L时并没有容将其前趋节点的next指向所删除节点的next.所以你这样做会把链表断开。也就不能构成一个链表了。所以这么做是错误的

㈣ C语言学生成绩管理系统中的链表排序怎么做

用冒泡排序!虽然效率低!比如:a[N]={3,2,5,4,2,6}for(int i = 0;i<(数组长度/2);i++) for(int j=i+1;j<数组长度;j++) if(a[i]>a[j]) { int temp = a[i]; a[i] = a[j]; a[j] = temp; }从第一个元素开始,依次往后面的元素比较,小的放前,大的放后,基本方法就这样了~!

㈤ c无序结构体链表按学生成绩排名的函数,求纠错!!

链表的排序,由于访问节点的限制,所以只有冒泡排序法比较合适
链表节点的交换,若交换的是内容,那两个节点直接交换就可以了。
若是要交换指针,那么需要知道三个节点的地址,
如链表a->b->c,交换b,c时我们要知道a,b,c三点的址址,
b->next=c->next;a->next=c;c->next=b;
当然,表头要单独处理
参考代码
#include <stdio.h>
#include <stdlib.h>
#define N sizeof(struct Student)

struct Student
{
long num;
float score;
struct Student* next;
};
void combine(struct Student* dest,struct Student* sour)
{
struct Student* p=dest;
while(p->next!=NULL)p=p->next;
p->next=sour;
}
struct Student *sort(struct Student *head)
{
struct Student *p,*q,*temp,*end=NULL;
struct Student cc;//为了避开表头交换,我们添加一个表头
for(cc.next=head; cc.next->next!=end;) //冒泡排序
{
for(q=&cc; q->next->next&& q->next->next!=end; q=q->next)
{
if(q->next->num > q->next->next->num)//对比,交换
{
temp=q->next->next;
q->next->next=q->next->next->next;
temp->next=q->next;
q->next=temp;
}
}
end=q->next;//下一次开始排序将不在比较排在后面的数据
}
return cc.next;//返回新表头
}

struct Student *getSruct()//第一个节点已存在,但未输入数据
{
struct Student *p,*head;
int n;
p=head=(struct Student *)malloc(N);
scanf("%ld%f",&p->num,&p->score);
p->next=NULL;
for(;scanf("%ld",&n),n>=0;)
{
p->next = (struct Student *)malloc(N);
p = p->next;
p->num=n;
scanf("%f",&p->score);
p->next = NULL;
}
return head;
}
void show(struct Student *p)
{
while(p)
{
printf("%ld %f\n",p->num,p->score);
p=p->next;
}
}

int main()
{
struct Student *a,*b;
a=getSruct();
b=getSruct();
combine(a,b);
a=sort(a);
show(a);
return 0;
}

㈥ 求链表实现学生成绩管理系统源代码(总成绩排序)

用链表去实现这个不是太麻烦了吗?直接用数据库就好了,不必要自己去写数据结构。

㈦ 将10个学生高等数学的成绩按由高到低的顺序排列建立一个有序的单链表

很简单啊。VC6.0环境编译通过。如果你用早期的dos环境下的编译器,输入输出流就改成printf(),scanf()这些了。 #include<iostream.h>
#define n 10
//using namespace std;
int j=0;
struct student
{
char name[20]; //名字
float results; //成绩
int numbers; //学号} sum[n],new_sum[n];
int out_r(int i)
{
// int i;
float s=60;
// for(i=0;i<n;i++)
if(sum[i].results>s) return 1;
else return 0;
}void swf_cp()
{
student fang;
int i,k;
for(i=0;i<j-1;i++)
for(k=i+1;k<j;k++)
{
if(new_sum[i].results>new_sum[k].results)
{
fang=new_sum[i];
new_sum[i]=new_sum[k];
new_sum[k]=fang;
}} }void main()
{
int i;//k;
// student new_sum[n];
for(i=0;i<n;i++)
{
cin>>sum[i].name>>sum[i].results>>sum[i].numbers;
}
for(i=0;i<n;i++)
{
if(out_r(i)) new_sum[j++]=sum[i];
}
swf_cp();
for(i=0;i<j;i++)
{
cout<<"名字= "<<new_sum[i].name<<endl;
cout<<"成绩= "<<new_sum[i].results<<endl;
cout<<"学号= "<<new_sum[i].numbers<<endl;
}
}

㈧ 建一个带头结点的学生信息(学号、姓名、成绩)单向链表,按成绩降序排列,打印输出,并计算及格人数。

这个貌似见过吧

http://..com/question/568351931?&oldq=1#answer-1433066328

干脆直接给附件,有问题专再说?属

㈨ 链表成绩排序

呵呵,这是我第一次用链表写,以你要求的功能,程序如下,有点长~
-------------------------------------------------------------
#include <stdio.h>
#include <stdlib.h>
#include <windows.h>
struct Student
{
long number;
char name[10];
float score[3];
float sum;
struct Student *next;
};
char Menu(void);
struct Student *App(struct Student *head);
void Ave(struct Student *head);
void Ser(struct Student *head);
void Pri(struct Student *head);
void Fre(struct Student *head);
int main(void)
{
struct Student *head=NULL;
while(1)
{
switch(Menu())
{
case '1':
printf("请入学生信息,直接输入'-1'结束\n");
head=App(head);
break;
case '2':
Ave(head);
break;
case '3':
Ser(head);
break;
case '4':
printf("学生信息如下:\n");
Pri(head);
break;
case '0':
printf("好累啊,88!\n");
exit(0);
default:
printf("请重新输入!\n");
}
fflush(stdin);
printf("按任意键继续~");
getchar();
system("cls");
}
Fre(head);
return 0;
}

char Menu(void)
{
char ch;
printf("------------请选择-----------\n");
printf("1.添加学生信息\n2.求学生各科平均分\n3.查找学生信息\n4.输出学生信息\n0.退出\n-----------------------------\n");
scanf(" %c",&ch);
return ch;
}

struct Student *App(struct Student *head)
{
struct Student *p=NULL,*q,*temp;
static i=1;
while(i)
{
p=(struct Student *)malloc(sizeof(struct Student));
q=head;
if(p==NULL)
{
printf("内存不够!\n");
exit(0);
}
printf("请输入第%d名学生的学号、姓名、语文/英语/数学分数:\n",i++);
p->next =NULL;
scanf("%ld",&p->number);
if(p->number ==-1)
{
i--;
break;
free(p);
}
scanf("%s%f%f%f",p->name ,&p->score[0],&p->score[1],&p->score[2]);
p->sum=p->score[0]+p->score[1]+p->score[2];
if(head==NULL)
head=p;
else
{
while(q->sum>p->sum&&q->next!=NULL)
{
temp=q;
q=q->next;
}
if(q->sum<=p->sum)
{
if(q==head)
{
p->next =q;
head=p;
}
else
{
temp->next = p;
p->next = q;
}
}
else
{
q->next =p;
}
}
}
return head;
}

void Ave(struct Student *head)
{
struct Student *p=head;
float sum[3]={0},ave[3];
int s[3]={0};
int i,count=0;
if(p!=NULL)
{
while(p!=NULL)
{
for(i=0;i<3;i++)
sum[i]+=p->score[i];
p=p->next;
count++;
}
for(i=0;i<3;i++)
ave[i]=sum[i]/count;
printf("语文/英语/数学平均分分别为:%.2f %.2f %.2f\n",ave[0],ave[1],ave[2]);
p=head;
while(p!=NULL)
{
for(i=0;i<3;i++)
if(p->score[i]<ave[i])
s[i]++;
p=p->next;
}
printf("语文/英语/数学低于平均分的人数分别为:%d %d %d\n",s[0],s[1],s[2]);
}
else
printf("你还没有录入学生成绩!\n");
}

void Ser(struct Student *head)
{
struct Student *p=head;
long s,flag=0;
printf("请输入要查找的学生学号:");
scanf("%ld",&s);
while(p!=NULL)
{
if(p->number ==s)
{
printf("学生信息如下:\n学号:%ld\n姓名:%s\n语文:%.1f 英语:%.1f 数学:%.1f\n",p->number ,p->name ,p->score[0],p->score[1],p->score[2]);
flag=1;
}
p=p->next ;
}
if(flag==0)
printf("没有找到该学生信息!\n");
}

void Pri(struct Student *head)
{
struct Student *p=head;
int i=1;
while(p!=NULL)
{
printf("%d. %ld %s %.1f %.1f %.1f\n",i++,p->number ,p->name ,p->score[0],p->score[1],p->score[2]);
p=p->next ;
}
}

void Fre(struct Student *head)
{
struct Student *p;
while(head!=NULL)
{
p=head;
head=head->next ;
free(p);
}
}

㈩ 急!!!!汇编学生成绩排序

; 题目名称:输入学生姓名、各科成绩,按总成绩降序排序并显示
; 题目来源:http://..com/question/130305629.html
; 操作说明:
; 1、本程序以5个科目为例,最多允许8个科目
; 2、姓名长度最多20个字符,输入姓名时,若直接回车,没有输入任何字符,则结束学生信息录入
; 3、输入姓名时,输足20个字符,自动结束姓名输入,开始输入成绩;不足20个字符,按回车键结束姓名输入
; 4、各科成绩最多3位数字,百分制。输入成绩时,若为100分,自动结束当前科目的输入;不足3位数字,按回车键结束当前成绩输入
; 本程序在MASMPlus 1.2集成环境下通过编译,经过调试,运行正确。
Code Segment
Assume CS:Code,DS:Code
CR equ 000DH
LF equ 000AH
KBBack equ 0008H
; -------------------------------------
; 学生成绩结构类型
Num equ 5 ;科目数,最多8个科目
Name_Length equ 20 ;姓名长度
Score_Stud Struc ; 学生成绩
Name_Stud db Name_Length p(?) ;姓名
Score db Num p(?) ;Num科成绩
Sum_Score dw ? ;总成绩
Score_Stud EndS
; -------------------------------------
; 功能:显示指定地址(Str_Addr)的字符串
; 入口:
; Str_Addr=字符串地址(要求在数据段)
; 用法: Output Str_Addr
; 用法举例:Output PromptStr
Output MACRO Str_Addr
lea dx,Str_Addr
mov ah,9
int 21h
EndM
; -------------------------------------
; 功能:在当前光标位置显示一个字符
; 入口:dl=要显示的字符
Output_Chr proc Near
push ax
mov ah,02h
int 21h
pop ax
ret
Output_Chr Endp
; -------------------------------------
; 功能:显示、输出一个回车、换行
Output_CTLF proc Near
push ax
push dx
mov ah,02h
mov dl,0dh
int 21h
mov dl,0ah
int 21h
pop dx
pop ax
ret
Output_CTLF Endp
; -------------------------------------
; 功能:取光标位置
; 入口:无
; 出口:DH=行号,DL=列号
GetCursor Proc Near
PUSH DS
PUSH AX
PUSH BX
PUSH CX
PUSH DX
PUSH CS
POP DS
XOR BX,BX
MOV AH,3
INT 10H
MOV Cursor_Row,DH
MOV Cursor_Col,DL
POP DX
POP CX
POP BX
POP AX
POP DS
RET
Cursor_Row DB ?
Cursor_Col DB ?
GetCursor EndP
; -------------------------------------
; 功能:置光标位置
; 入口:Cursor_Row=行坐标; Cursor_Col: 列坐标)
SetCursor Proc Near
PUSH DS
PUSH DX
PUSH CX
PUSH BX
PUSH AX
PUSH CS
POP DS
MOV DH,Cursor_Row
MOV DL,Cursor_Col
XOR BX,BX
MOV AH,2
INT 10H
POP AX
POP BX
POP CX
POP DX
POP DS
RET
SetCursor EndP
; -------------------------------------
; 功能:键盘输入一个指定位数(N)的十进制数字,将其转换成二进制数并保存在指定的内存单元。
; 输足N位的,自动结束输入;不足N位的,空格结束输入。
; 由于限定最大数据类型为字,所以,数字位数最多:5,最大无符号数:65536
; 约定:直接回车,视为数字0
; 入口:cs:@@Digits=数字位数;es:di=保存输入的数字首地址
; cs:@@Type_Data=保存的数据类型,B=字节类型,W=字类型。
; 出口:转换后的二进制数保存在di所指的单元
Input_Dec Proc Near
push ds
push dx
push cx
push bx
push di
push cs
pop ds
call GetCursor ;取光标位置
mov dx,WORD PTR Cursor_Row
mov @@Tmp_Cursor,dx ;保存起始光标位置
lea di,@@Save_Tmp
push di
cld
mov cl,@@Digits
xor ch,ch
push cx
@@Input_Dec: call GetCursor ;取光标位置
mov ah,1 ;从键盘接受一个字符
int 21h
cmp al,CR ;若键入的是回车,已经键入的数字不足N位
jz @@ASC_Dec ;转去处理已经键入的数字
cmp al,KBBack
jz @@KB_Back ;若是回空键,重新输入
cmp al,'0'
jb @@KBBack ;若低于数字'0',重新输入
cmp al,'9'
ja @@KBBack ;若高于数字'9',重新输入
jmp @@Save_Dig
@@KB_Back: cmp cl,cs:@@Digits ;十进制数字位数
jz @@Input_Dec
inc cx
dec di
dec Cursor_Col
@@KBBack: call SetCursor ;置光标位置
jmp @@Input_Dec
@@Save_Dig: and al,0fh ;转换成二进制数
stosb ;保存
loop @@Input_Dec ;接受下一个数字
@@ASC_Dec: mov ax,cx
pop cx
pop si
sub cx,ax ;实际输入的数字位数
xor bp,bp
xor dx,dx
xor ax,ax
jcxz @@Save_Ret ;若直接回车,没有输入任何数字,按输入'0'处理
dec cx ;实际输入的数字位数减1,准备把输入的这一串数字转换成二进制数
jcxz @@One_Digit ;若输入的数字只有一位,转去直接保存这个二进制数
mov bx,10
@@Mul_Ten: lodsb
xor ah,ah
add ax,bp
mul bx
mov bp,ax
loop @@Mul_Ten
@@One_Digit: lodsb
xor ah,ah
add ax,bp
@@Save_Ret: pop di
cmp @@Type_Data,'B' ;字节类型?
jz $+5
stosw
jmp $+3
stosb
pop bx
pop cx
pop dx
pop ds
ret
@@Tmp_Cursor dw ? ;起始光标位置
@@Digits db ? ;十进制数字位数
@@Type_Data db 'B' ;保存的数据类型。B=字节类型,W=字类型
@@Save_Tmp db 7 p(?)
Input_Dec EndP
; -------------------------------------
; 功能:把AX中的二进制无符号数转换成显式的十进制ASCII码,并送显示屏显示
; 入口:AX=二进制数
; 出口:在当前光标位置显示转换后的ASCII码数字
Unsi_Dec_ASCII Proc Near
push dx
push bx
push di
mov bx,10
lea di,@@Temp_Save[5]
mov BYTE PTR [di],'$'
dec di
cld
@@Divide: xor dx,dx
div bx
or dl,30h
mov [di],dl
dec di
test ax,0ffffh
jnz @@Divide
inc di
push di
pop dx
mov ah,9
int 21h
pop di
pop bx
pop dx
ret
@@Temp_Save db 6 p(?)
Unsi_Dec_ASCII EndP
; -------------------------------------
N equ 3 ;学生成绩数字位数
Prompt_Str db 'Please input the name and score.',13,10,13,10,7
db 7,'Name',Name_Length-4+2 p(20h)
Score_Str db Num*8+9 p(?) ;科目标题字符串缓冲区(预留8个科目的标题)
Temp_Str db 'Score? '
Summation db 'Summation'
Temp_Cursor dw ? ;输入、显示学生信息光标位置
Press_Key db 7,13,10,13,10,'The complated. Press any key to exit...$'
Start: push cs
pop ds
push cs
pop es ;使数据段、附加段与代码段同段
mov @@Digits,N ;十进制数字位数
mov @@Type_Data,'B' ;保存的数据类型。B=字节类型,W=字类型
; -------------------------------------
; 生成并显示输入学生姓名、各科成绩标题信息
lea si,Temp_Str ;样板标题字符串地址
lea di,Score_Str ;科目标题字符串地址
mov cx,Num ;科目数
mov dl,'1' ;科目序号初值
cld
Title_Str: mov [si][5],dl ;修改科目序号
push cx
push si
mov cx,8 ;样板标题字符串长度
rep movsb ;复制一个科目标题字符串
pop si
pop cx
inc dl ;科目序号增1
loop Title_Str ;下一个科目
lea si,Summation
mov cx,9
rep movsb
mov ax,0a0dh ;回车、换行
stosw
mov al,'$'
stosb
Output Prompt_Str ;提示输入姓名、成绩
mov al,Num ;科目数
mov ah,8 ;每科标题长度
mul ah
mov cx,ax
add cx,Name_Length ;加上姓名长度
add cx,11 ;加总分标题长度
mov dl,'-'
@@L0: call Output_Chr ;显示一个字符
loop @@L0
call Output_CTLF ;输出一个回车、换行
call GetCursor ;取光标位置
mov dx,WORD ptr Cursor_Row
xchg dh,dl
mov Temp_Cursor,dx ;保存输入、显示学生信息光标位置
; -------------------------------------
; 输入学生姓名、各科成绩
lea di,List_Score ;姓名、成绩存放地址
Input_Name: call GetCursor ;取光标位置
push di
lea di,Buffer_Name[2]
mov cx,5
mov ax,2020h
rep stosw
pop di
lea dx,Buffer_Name ;学生姓名输入缓冲区地址
mov ah,0ah
int 21h
lea si,Buffer_Name[1]
lodsb ;读入实际输入的字符个数
test al,0ffh
jz @@L1 ;若输入学生姓名时,直接回车,认为学生姓名、成绩等输入结束,转去计算输入的学生人数
mov cx,Name_Length ;姓名字符数
push di
rep movsb ;写入姓名、成绩暂存地址保存
pop di
add di,LENGTH Name_Stud ;第1科成绩存放地址
add Cursor_Col,Name_Length+2 ;列号加姓名长度再加2,开始输入成绩
call SetCursor ;置光标位置
mov cx,Num ;科目数,开始输入成绩
xor bx,bx ;总成绩初值
push di ;某科成绩存放地址
Input_Score: call Input_Dec ;输入成绩
add bx,ax ;累加各科成绩
add Cursor_Col,6 ;列号加6,输入下一科成绩光标位置
call SetCursor ;置光标位置
loop Input_Score ;输入下一科成绩
mov [di],bx ;保存总成绩
mov ax,bx
call Unsi_Dec_ASCII ;把AX中的二进制无符号数转换成显式的十进制ASCII码,并送显示屏显示
pop di
add di,Num+Type Sum_Score ;下一名学生姓名、各科成绩存放地址
call Output_CTLF ;输出一个回车、换行
jmp Input_Name ;输入下一名学生姓名、各科成绩
; -------------------------------------
; 计算输入的学生人数
@@L1: mov ax,di
sub ax,offset List_Score ;所有学生姓名、各科成绩所占内存容量
mov bl,type Score_Stud ;每名学生信息所占内存容量
div bl
mov cx,ax ;CX=输入的学生人数
test cx,cx
jnz @@L00
jmp Exit_Proc ;若未输入任何信息,直接结束程序
; -------------------------------------
; 建立学生信息链表
@@L00: push di ;保存链表地址
lea ax,List_Score ;学生信息起始地址
push cx
@@L2: stosw ;保存学生信息地址
add ax,type Score_Stud ;每名学生信息所占内存容量
loop @@L2
pop cx
pop si ;弹出链表地址给si
cmp cx,2
jb Exit_Proc ;若只输入了1名学生的信息,则无须排序和显示结果
; -------------------------------------
; 用冒泡排序法按总成绩降序排序
push si ;入栈保存链表地址
push cx ;保存学生人数
dec cx ;准备用冒泡排序法排序
@@Sorting: push cx ;入栈保存外循环次数
push si ;入栈保存数组地址
@@Compare: push si
pop di ;当前数组元素地址赋给目的变址寄存器,以备交换之用
lodsw ;将当前数组元素读入累加器
mov bx,ax
mov ax,[bx.Sum_Score] ;将当前学生总成绩读入累加器AX
mov bx,[si] ;相邻的下一个学生信息地址
cmp ax,[bx.Sum_Score] ;当前学生总成绩与相邻的下一个学生总成绩相比较
jae @@NextOne ;若大于或等于,不作数据交换,处理下一个数组元素
mov ax,[di] ;若小于,读入当前学生信息链表节点
xchg ax,[si] ;交换链表元素
mov [di],ax ;保存数值较大者节点地址
@@NextOne: loop @@Compare ;处理下一个数组元素
pop si ;数组地址出栈
pop cx ;外循环次数出栈
loop @@Sorting ;下一趟比较
; -------------------------------------
; 按总成绩降序显示所有学生姓名、各科成绩和总成绩
xor bh,bh ;页号0
mov ah,8 ;读光标位置的字符和属性
int 10h
mov bh,ah ;字符属性
mov cx,Temp_Cursor ;取输入、显示学生信息光标位置(滚动窗口左上角坐标)
mov dx,184fh ;滚动窗口右下角坐标
mov al,dh
inc al
sub al,ch ;滚动行数
mov ah,6 ;显示内容上滚
int 10h
mov dx,Temp_Cursor ;取输入、显示学生信息光标位置
xor bx,bx
mov ah,2 ;设置光标位置
int 10h
pop cx ;弹出学生人数
pop si ;弹出链表地址
@List_Score: push cx ;保存学生人数
call GetCursor ;取光标位置
lodsw ;读入链表的一个节点
push si ;入栈保存链表地址
mov si,ax
push si ;入栈学生信息地址
lea si,[si.Name_Stud] ;姓名地址
mov cx,Name_Length ;姓名字符串长度
@@Dsip_Name: lodsb ;读入一个字符
cmp al,0dh ;回车符?
jz @@L3 ;是,姓名显示结束,开始显示成绩
mov dl,al
call Output_Chr ;显示一个字符
loop @@Dsip_Name ;下一个字符
@@L3: add Cursor_Col,Name_Length+2 ;列号加姓名长度再加2,开始显示成绩
call SetCursor ;置光标位置
pop si ;弹出学生信息地址
lea si,[si.Score] ;各科分数地址
mov cx,Num ;科目数
@Disp_Score: lodsb ;读入一科分数
xor ah,ah
call Unsi_Dec_ASCII ;把AX中的二进制无符号数转换成显式的十进制ASCII码,并送显示屏显示
add Cursor_Col,8 ;列号加8,显示下一科分数光标位置
call SetCursor ;置光标位置
loop @Disp_Score ;下一科分数
lodsw ;读入各科总分
call Unsi_Dec_ASCII ;把AX中的二进制无符号数转换成显式的十进制ASCII码,并送显示屏显示
call Output_CTLF ;输出一个回车、换行
pop si ;弹出链表地址
pop cx ;弹出学生人数
loop @List_Score ;下一个节点(学生信息)
; -------------------------------------
Exit_Proc: Output Press_Key ;提示操作完成,按任意键结束程序
mov ah,1
int 21h
mov ah,4ch ;结束程序
int 21h
even
Buffer_Name db 9,?,10 p(?) ;学生姓名输入缓冲区
List_Score: ;姓名、成绩暂存地址
Code ENDS
END Start ;编译到此结束

热点内容
武汉大学学生会辅导员寄语 发布:2021-03-16 21:44:16 浏览:612
七年级学生作文辅导学案 发布:2021-03-16 21:42:09 浏览:1
不屑弟高考成绩 发布:2021-03-16 21:40:59 浏览:754
大学毕业证会有成绩单 发布:2021-03-16 21:40:07 浏览:756
2017信阳学院辅导员招聘名单 发布:2021-03-16 21:40:02 浏览:800
查询重庆2018中考成绩查询 发布:2021-03-16 21:39:58 浏览:21
结业考试成绩怎么查询 发布:2021-03-16 21:28:40 浏览:679
14中医医师资格笔试考试成绩查分 发布:2021-03-16 21:28:39 浏览:655
名著赏析课程标准 发布:2021-03-16 21:27:57 浏览:881
北京大学商业领袖高端培训课程 发布:2021-03-16 21:27:41 浏览:919