学生成绩管理系统

功能

1.从文件中读取数据

2.按照平均分排名,并写入文件,按照学号排序,写入文件

3.统计每门课程的平均分,统计各分数段的人数,写入文件

4.打印成绩条

5.显示不及格学生信息,写入文件

6.显示优等生信息,写入文件

代码

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
//定义学生的最大数量
#define MAXNMB 50
//定义课程数量
#define NMBKC 5
struct Student
{
	int number;      //学号
	char name[20];   //姓名
	int score[NMBKC];//保存课程成绩
	float avg;       //平均分
	int mc;          //名次
};
//显示信息
void Display(struct Student stu[],int nmb,char kecheng[][20])
{
	int i;
	char* xh ="学号";
	char* xm ="姓名";
	printf("%-6s%-8s",xh,xm);
	for(i=0;i<NMBKC;i++)
		printf("%-10s",kecheng[i]);
	printf("\n");
	for (i = 0;i< nmb;i++)
	{
		printf("%-6d%-10s%-10d%-10d%-10d%-10d%-10d\n",stu[i].number,stu[i].name,stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4]);
	}
}
//解析数据
int ParserStr(char* buf,char out[NMBKC][20])
{
	int i = 0;
	int j = 0,m = 0;;
	char prech = 'a';
	//去掉开头的空格
	while(buf[i] == ' ')
		i++;
	while(buf[i] != '\0')
	{
		if (buf[i] == '\n' && prech != ' ')
		{
			out[j][m] = '\0';
			//printf("%d  %s\n",j,out[j]);
			prech = ' ';
			m = 0;
			j++;
			i++;
		}else if(buf[i] == ' ' && prech != ' ')
		{
			out[j][m] = '\0';
			//printf("%d  %s\n",j,out[j]);
			prech = ' ';
			m = 0;
			j++;
			i++;
		}else if (buf[i] == ' ' && prech == ' ')
		{
			i++;
		}else
		{
			out[j][m] = buf[i];
			prech = buf[i];
			m++;
			i++;
		}
	}
	if (j== NMBKC+2)
	{
		return 1;
	}else
		return 0;
}
//读取文件
void ReadFile(struct Student stu[],int *nmb,char kecheng[][20])
{
	int i = 0,j = 0;
	char buf[100] = {0};
	char tmp[NMBKC+2][20] = {0};
	int t;
	FILE* fp;
	errno_t err;
	if ((err = fopen_s(&fp,"a.txt","r")) != 0)
	{
		printf("文件读取失败\n");
		return ;
	}
	//读取文件
	//第一行数据
	fgets(buf,100,fp);
	//解析数据
	ParserStr(buf,tmp); //解析出课程名称
	for (j =0;j < NMBKC;j++)
	{
		strcpy_s(kecheng[j],20,tmp[j+2]);
	}
	while(!feof(fp))
	{
		memset(buf,0,100);
		fgets(buf,100,fp); //读取一行
		//避免最后一行直接结束
		if(buf[strlen(buf)-1] != '\n')
			buf[strlen(buf)] = ' ';
		memset(tmp,0,sizeof(tmp));
		if(ParserStr(buf,tmp))
		{
			stu[i].number = atoi(tmp[0]);
			strcpy_s(stu[i].name,20,tmp[1]);
			stu[i].avg = 0.0;
			for(t = 0;t < NMBKC;t++)
			{
				stu[i].score[t] = atoi(tmp[2+t]);
				stu[i].avg += stu[i].score[t];
			}
			stu[i].avg /= NMBKC;
			i++;
		}
	}
	fclose(fp);
	*nmb = i;
	//printf("总学生数:%d\n",i);
}
//按平均分排名
void SortByavg(struct Student stu[],int nmb,char kecheng[][20])
{
	int i,j;
	errno_t err;
	struct Student tmp;
	char* xh ="学号";
	char* xm ="姓名";
	char* pjf ="平均分";
	char* pm="排名";
	FILE* fp;
	printf("%-6s%-8s",xh,xm);
	for(i=0;i<NMBKC;i++)
		printf("%-10s",kecheng[i]);
	printf("%-10s%-10s\n",pjf,pm);
	for (i = 0;i< nmb-1;i++)
	{
		for (j = 0;j<nmb-1-i;j++)
		{
			if(stu[j].avg < stu[j+1].avg)
			{
				tmp = stu[j];
				stu[j] = stu[j+1];
				stu[j+1] = tmp;
			}
		}
	}
	//屏幕显示
	j = 1;
	for (i = 0;i<nmb;i++)
	{
		if (i == 0)
		{
			stu[i].mc = 1;
			printf("%-6d%-10s%-10d%-10d%-10d%-10d%-10d%.2f%5d\n",stu[i].number,stu[i].name,stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4],stu[i].avg,j);
		}else
		{
			if(stu[i].avg != stu[i-1].avg)
				j++;
			stu[i].mc = j;
			printf("%-6d%-10s%-10d%-10d%-10d%-10d%-10d%.2f%5d\n",stu[i].number,stu[i].name,stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4],stu[i].avg,j);
		}
	}
	//写文件
	if ((err = fopen_s(&fp,"file2.txt","w")) != 0)
	{
		printf("文件打开失败\n");
		return;
	}
	//屏幕显示
	fprintf(fp,"%-6s%-8s",xh,xm);
	for(i=0;i<NMBKC;i++)
		fprintf(fp,"%-10s",kecheng[i]);
	fprintf(fp,"%-10s%-10s\n",pjf,pm);
	j = 1;
	for (i = 0;i<nmb;i++)
	{
		if (i == 0)
		{
			fprintf(fp,"%-6d%-10s%-10d%-10d%-10d%-10d%-10d%.2f%5d\n",stu[i].number,stu[i].name,stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4],stu[i].avg,j);
		}else
		{
			if(stu[i].avg != stu[i-1].avg)
				j++;
			fprintf(fp,"%-6d%-10s%-10d%-10d%-10d%-10d%-10d%.2f%5d\n",stu[i].number,stu[i].name,stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4],stu[i].avg,j);
		}
	}
	fclose(fp);
}
//按学号排名
void SortByxh(struct Student stu[],int nmb,char kecheng[][20])
{
	int i,j;
	struct Student tmp;
	errno_t err;
	char* xh ="学号";
	char* xm ="姓名";
	char* pjf ="平均分";
	char* pm="排名";
	FILE* fp;
	//写文件
	printf("%-6s%-8s",xh,xm);
	for(i=0;i<NMBKC;i++)
		printf("%-10s",kecheng[i]);
	printf("%-10s%-10s\n",pjf,pm);
	for (i = 0;i< nmb-1;i++)
	{
		for (j = 0;j<nmb-1-i;j++)
		{
			if(stu[j].number > stu[j+1].number)
			{
				tmp = stu[j];
				stu[j] = stu[j+1];
				stu[j+1] = tmp;
			}
		}
	}
	//屏幕显示
	for (i = 0;i<nmb;i++)
	{
		printf("%-6d%-10s%-10d%-10d%-10d%-10d%-10d%.2f%5d\n",stu[i].number,stu[i].name,stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4],stu[i].avg,stu[i].mc);
	}
	//写文件
	if ((err = fopen_s(&fp,"file1.txt","w")) != 0)
	{
		printf("文件打开失败\n");
		return;
	}
	//写文件
	fprintf(fp,"%-6s%-8s",xh,xm);
	for(i=0;i<NMBKC;i++)
		fprintf(fp,"%-10s",kecheng[i]);
	fprintf(fp,"%-10s%-10s\n",pjf,pm);
	for (i = 0;i<nmb;i++)
	{
		fprintf(fp,"%-6d%-10s%-10d%-10d%-10d%-10d%-10d%.2f%5d\n",stu[i].number,stu[i].name,stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4],stu[i].avg,stu[i].mc);
	}
	fclose(fp);
}
//统计每门课程的平均分
void TongjiKcpjf(struct Student stu[],int nmb,char kecheng[][20])
{
	int i,j;
	errno_t err;
	FILE* fp;
	float avg[NMBKC];  //保存每门课程的平均分
	int a[5][NMBKC];   //保存每个分数段的数量
	char* d0 = "分数段";
	char* ds[] = {"<60","60-69","70-79","80-89",">=90"};
	char* pjf = "平均分";
	//计算课程平均分
	for (i=0;i<NMBKC;i++)
	{
		avg[i] = 0.0;
		for (j = 0;j< nmb;j++)
			avg[i] += stu[j].score[i];
		avg[i] /= nmb;
	}
	//初始化数量
	for (i=0;i<5;i++)
	{
		for(j=0;j<NMBKC;j++)
			a[i][j] = 0;
	}
	//统计各分数段数量
	for (i=0;i<nmb;i++)
	{
		for(j=0;j<NMBKC;j++)
		{
			if(stu[i].score[j]< 60)
				a[0][j] += 1;
			else if(stu[i].score[j]>= 60 && stu[i].score[j]<= 69)
				a[1][j] +=1;
			else if(stu[i].score[j]>= 70 && stu[i].score[j]<= 79)
				a[2][j] +=1;
			else if(stu[i].score[j]>= 80 && stu[i].score[j]<= 89)
				a[3][j] +=1;
			else
				a[4][j] +=1;
		}
	}
	//打印
	printf("%-6s  ",d0);
	for(i=0;i<NMBKC;i++)
		printf("%-10s",kecheng[i]);
	printf("\n");
	for (i = 0;i< 5;i++)
	{
		printf("%-6s  ",ds[i]);
		for(j=0;j<NMBKC;j++)
			printf("%-10d",a[i][j]);
		printf("\n");
	}
	printf("%-6s  ",pjf);
	for (i=0;i<NMBKC;i++)
	{
		printf("%.2f     ",avg[i]);
	}
	printf("\n");
	//写文件
	if ((err = fopen_s(&fp,"file3.txt","w")) != 0)
	{
		printf("文件打开失败\n");
		return;
	}
	//写
	fprintf(fp,"%-6s  ",d0);
	for(i=0;i<NMBKC;i++)
		fprintf(fp,"%-10s",kecheng[i]);
	fprintf(fp,"\n");
	for (i = 0;i< 5;i++)
	{
		fprintf(fp,"%-6s  ",ds[i]);
		for(j=0;j<NMBKC;j++)
			fprintf(fp,"%-10d",a[i][j]);
		fprintf(fp,"\n");
	}
	fprintf(fp,"%-6s  ",pjf);
	for (i=0;i<NMBKC;i++)
	{
		fprintf(fp,"%.2f     ",avg[i]);
	}
	fprintf(fp,"\n");
	fclose(fp);
}
//打印成绩条
void DisplayCjt(struct Student stu[],int nmb,char kecheng[][20])
{
	int i,j;
	errno_t err;
	struct Student tmp;
	char* xh ="学号";
	char* xm ="姓名";
	char* pjf ="平均分";
	char* pm="排名";
	FILE* fp;
	for (i = 0;i< nmb-1;i++)
	{
		for (j = 0;j<nmb-1-i;j++)
		{
			if(stu[j].number > stu[j+1].number)
			{
				tmp = stu[j];
				stu[j] = stu[j+1];
				stu[j+1] = tmp;
			}
		}
	}
	//屏幕显示
	for (i = 0;i<nmb;i++)
	{
		printf("%-6d%-10s%-10d%-10d%-10d%-10d%-10d%.2f%5d\n",stu[i].number,stu[i].name,stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4],stu[i].avg,stu[i].mc);
	}
	//写文件
	if ((err = fopen_s(&fp,"file4.txt","w")) != 0)
	{
		printf("文件打开失败\n");
		return;
	}
	//写文件
	fprintf(fp,"%-6s%-8s",xh,xm);
	for(i=0;i<NMBKC;i++)
		fprintf(fp,"%-10s",kecheng[i]);
	fprintf(fp,"%-10s%-10s\n",pjf,pm);
	for (i = 0;i<nmb;i++)
	{
		fprintf(fp,"%-6d%-10s%-10d%-10d%-10d%-10d%-10d%.2f%5d\n",stu[i].number,stu[i].name,stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4],stu[i].avg,stu[i].mc);
	}
	fclose(fp);
}
//打印所有不及格信息
void DisplayBjg(struct Student stu[],int nmb,char kecheng[][20])
{
	int i,j;
	FILE* fp;
	errno_t err;
	int bw = 0;
	char buf[100]={0};
	char tmp[10];
	if((err = fopen_s(&fp,"file5.txt","w")) != 0)
	{
		printf("文件打开失败\n");
		return ;
	}
	for (i = 0;i< nmb;i++)
	{
		bw = 0;
		memset(buf,0,100);
		for (j = 0;j< NMBKC;j++)
		{
			if(stu[i].score[j]< 60)
			{
				memset(tmp,0,10);
				strcat_s(buf,100,kecheng[j]);
				strcat_s(buf,100,"(");
				_itoa_s(stu[i].score[j],tmp,10,10);
				strcat_s(buf,100,tmp);
				strcat_s(buf,100,")  ");
				bw = 1;
			}
		}
		if(bw)
		{
			printf("%d  %s  %s\n",stu[i].number,stu[i].name,buf);
			fprintf(fp,"%d  %s  %s\n",stu[i].number,stu[i].name,buf);
		}
	}
	fclose(fp);
}
//判断是否是优等生
int isYds(struct Student st)
{
	int i;
	int tt = 0;
	int flag1 = 0,flag2 = 0,flag3 = 1;
	if (st.avg > 90)
	{
		flag1 = 1;
	}
	for (i=0;i<NMBKC;i++)
	{
		if(st.score[i] == 100 && st.avg > 85)
			flag1 = 1;
		if(st.score[i] > 95)
			tt++;
		if(st.score[i]< 60)
			flag3 = 0;
	}
	if(tt>=2 && st.avg > 85)
		flag1 = 1;
	if(st.mc <=3 )
		flag2 = 1;
	if (flag1 && flag2 && flag3)
	{
		return 1;
	}
	return 0;
}
//打印优等生
void DisplayYds(struct Student stu[],int nmb,char kecheng[][20])
{
	int i;
	errno_t err;
	FILE* fp;
	char* xh ="学号";
	char* xm ="姓名";
	char* pjf ="平均分";
	char* pm="排名";
	if((err = fopen_s(&fp,"file6.txt","w")) != 0)
	{
		printf("文件打开失败\n");
		return ;
	}
	//终端输出
	printf("%-6s%-8s",xh,xm);
	for(i=0;i<NMBKC;i++)
		printf("%-10s",kecheng[i]);
	printf("%-10s%-10s\n",pjf,pm);
	//写文件
	fprintf(fp,"%-6s%-8s",xh,xm);
	for(i=0;i<NMBKC;i++)
		fprintf(fp,"%-10s",kecheng[i]);
	fprintf(fp,"%-10s%-10s\n",pjf,pm);
	for (i=0;i<nmb;i++)
	{
		if(isYds(stu[i]))
		{
			printf("%-6d%-10s%-10d%-10d%-10d%-10d%-10d%.2f%5d\n",stu[i].number,stu[i].name,stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4],stu[i].avg,stu[i].mc);
			fprintf(fp,"%-6d%-10s%-10d%-10d%-10d%-10d%-10d%.2f%5d\n",stu[i].number,stu[i].name,stu[i].score[0],stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4],stu[i].avg,stu[i].mc);
		}
	}
	fclose(fp);
}
int main()
{
	struct Student stu[MAXNMB];
	int nmb;  //实际学生人数,从文件中读取
	char kc[NMBKC][20] = {0};  //保存课程名称
	//1.从文件中读取数据
	printf("-------------------1.读入原始数据并显示---------------------\n");
	ReadFile(stu,&nmb,kc);
	Display(stu,nmb,kc);
	//2.排序
	printf("-------------------2.1根据平均分排序并显示------------------\n");
	SortByavg(stu,nmb,kc); //现根据平均分排序
	printf("-------------------2.2根据学号排序并显示--------------------\n");
	SortByxh(stu,nmb,kc);  //再根据学号排序,因为首选需要根据平均分排序才能得到名次
	//3.统计课程平均分
	printf("-------------------3.统计课程平均分并显示--------------------\n");
	TongjiKcpjf(stu,nmb,kc);
	//4.打印成绩条
	printf("-------------------4.打印成绩条------------------------------\n");
	DisplayCjt(stu,nmb,kc);
	//5.打印不及格成绩
	printf("-------------------5.打印不及格成绩---------------------------\n");
	DisplayBjg(stu,nmb,kc);
	//6.打印优等生
	printf("-------------------6.打印优等生-------------------------------\n");
	DisplayYds(stu,nmb,kc);
	getchar();
	getchar();
	return 0;
}

数据文件

a.txt

学号  姓名     英语     C语言     高等数学  大学物理   体育
1     张三      77        89        78        78        80
2     李四      88        44        85        33        55
3     杨潇      68        67        85        68        91
4     韦一笑    78        67        85        68        95
5     周芷若    88        100       85        90        93
6     包不同    66        56        45        68        89
7     段誉      76        67        85        68        70
8     王语嫣    56        67        85        68        77
9     杨过      82        56        85        68        99
10    小龙女    81        67        85        68        92
11    虚竹      87        100       85        90        88

相当不错的一个成绩管理系统 #include #include #include #include using namespace std; enum {SUBJECT=5};//一共五门 typedef struct { char subject[10];//科目名称 int score;//科目成绩 }markinfo; typedef struct studentnode { markinfo mark[SUBJECT]; int totalmark; char name[10];//学生姓名 studentnode * next; }studentnode; class student { studentnode * head; public: student(); int addstudent(); ~student(); int countmark(); int sortbymark(); int save(); int show(); int display(); int readfiletolist(); int searchbyname(); }; student::student() //用构造函数来初始化。 { head=new studentnode; head->next=NULL; } //1.输入学生姓名、成绩等数据,并保存在链表中。 int student::addstudent() { studentnode * p; int i; char check; system("cls"); cout<<"**********************"<<endl; cout<<"请输入学生信息:"<<endl; do { p=new studentnode; cin.ignore(); cout<name); i=0; p->totalmark=0; do { cout<mark[i].subject); cout<>p->mark[i].score; } while(p->mark[i].score>100||p->mark[i].scoretotalmark=p->totalmark+p->mark[i].score; getchar(); } while(++i!=SUBJECT); if(head->next==NULL) { head->next=p;p->next=NULL; } else { p->next=head->next; head->next=p; } cout<next; if(p==NULL) { cout<<"没有学生,请重新输入"<<endl;system("pause");return 0; } else { cout<<"***************"<<endl; cout<<"学生成绩汇总:"<<endl; while(p) { cout<<"姓名:"<name<<" 总成绩:"<totalmark<next; } } system("pause"); return 0; } //4.输出所有学生成绩到一个文件中。 int student::save() { char address[35]; int i; studentnode * p=head->next; cout<<"请输入保存的地址"<<endl; cin.ignore(); gets(address); ofstream fout; fout.open(address,ios::app|ios::out); while(p) { fout<<"*"; fout<name<<"*"; i=0; while(i!=SUBJECT) { fout<mark[i].subject<<"*"; fout<mark[i].score; i++; } //fout<next; } fout.flush(); fout.close(); cout<next; while(p) { s=p->next; delete p; p=s; } delete head; } //3.按照总成绩大小对记录进行排序 int student::sortbymark() { studentnode *move1=head->next; studentnode *move2,*max,*pre1,*pre2,*maxpre,*s=move1; if(head->next==NULL) { cout<<"没有记录,请添加"<next!=NULL;pre1=move1,maxpre=pre1,move1=move1->next,max=move1) { for(pre2=move1,move2=move1->next;move2!=NULL;pre2=move2,move2=move2->next) if(move2->totalmark>max->totalmark) { maxpre=pre2; max=move2; } if(move1->next==max) //交换max和move1。 { pre1->next=max; move1->next=max->next; max->next=move1; move1=max; } else { s=move1->next; move1->next=max->next; max->next=s; maxpre->next=move1; pre1->next=max; move1=max; } } cout<<"已经按照从大到小排序"<next; int i; if(head->next==NULL){cout<<"没有学生记录,请添加"<<endl;system("pause"); return 0;} else { while(p) { cout<<"姓名:"<name; i=1; while(i!=SUBJECT+1) { cout<<"科目:"<mark[i-1].subject; cout<<" 成绩:"<mark[i-1].score; i++; } cout<next; } } system("pause"); return 0; } //6:从文件按读取记录 int student::display() { ifstream fin; char buf[100]; char str[25]; cout<<"请输入路径及文件名:"<<endl; cin.ignore(); gets(str); fin.open(str); if(!fin) { cout<<"没有此文件"<<endl; system("pause"); return 0; } while(fin) { fin.getline(buf,sizeof(buf)); cout<<buf<<endl; } system("pause"); return 0; } //8从文件中读取数据,并将数据保存在链表中 int student::readfiletolist() { ifstream fin; int i; char str[25]; cout<<"请输入路径及文件名:"<<endl; cin.ignore(); gets(str); fin.open(str); if(!fin) { cout<<"没有此文件"<totalmark=0; fin.getline(p->name,100,'*'); i=0; while(i!=SUBJECT) { fin.getline(p->mark[i].subject,100,'*'); fin>>p->mark[i].score; p->totalmark+=p->mark[i].score; i++; } if(head->next==NULL) { head->next=p; p->next=NULL; } else { p=head->next; head->next=p; } } cout<<"信息已经保存在链表中"<next==NULL) { cout<<"没有学生,请添加或者从文件中读取"<next; char findname[10]; int i; cout<name,findname)) { cout<<"经查找,找到该生信息如下:"<<endl<<endl; cout<<"姓名:"<name; i=1; while(i!=SUBJECT+1) { cout<<"科目:"<mark[i-1].subject; cout<<" 成绩:"<mark[i-1].score; i++; } cout<next; } cout<<"没有此学生,请添加或者从文件中读取"<<endl; system("pause"); return 0; } int showmenu() { int choice; char * menu[9]={ "1:输入学生成绩保存到链表\n", "2:计算每位学生总成绩\n", "3:按照总成绩大小对记录进行排序\n", "4:输出所有学生成绩到一个文件中\n", "5:显示新输入的学生信息\n", "6:从文件中读取信息\n", "7:将文件信息保存在链表中\n", "8:根据姓名查找学生记录\n", "9:结束程序\n" }; cout<<" "<<"*****************************************************"<<endl; cout<<" *"<<" "<<"学生成绩管理系统"<<" *"<<endl; cout<<" "<<"*****************************************************"<<endl; for(choice=0;choice<9;choice++) cout<<" "<<menu[choice]; cout<<" "<<"*****************************************************"<<endl; cout<<"please choose to continue"<>choice; } while(choice>9||choice<1); return choice; } int main() { int menuitem,flag=1; student stu; while(flag) { system("cls"); menuitem=showmenu(); switch(menuitem) { case 1:{stu.addstudent();break;} case 2:{stu.countmark();break;} case 3:{stu.sortbymark();break;} case 4:{stu.save();break;} case 5:{stu.show();break;} case 6:{stu.display();break;} case 7:{stu.readfiletolist();break;} case 8:{stu.searchbyname();break;} case 9:{flag=0;break;} } } return 0; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qfl_sdu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值