當前位置:首頁 » 考試成績 » 排序鏈表學生成績

排序鏈表學生成績

發布時間: 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