湘大的公共选修课怎么选啊

湘大的公共选修课怎么选啊,第1张

1.学生在选课期间登录湘潭大学教务管理系统进行网上选课。具体步骤如下:选课管理→选课→学期(从进校算起)→选课级次(如:2013年上学期公共选修课选课)→选课类型(通识教育选课、文化素质选课)→点击通识教育课程名称可以显示上课时间和地点,以电子课表为准上课。

2.学生选课前务必交清学费,否则不能选课。

3 通识教育非毕业年级限选1门,毕业年级限选4门;文化自修课非毕业年级限选1门,毕业年级限选2门。

4学生可在校园内任意一台联网计算机上进行选课并查询自己的选课情况,如:图书馆、计算中心、学院机房等。

这个是我以前做个的挺好的系统,你可以改改,很简单。我也给你邮箱发了一份,注意查收,一定给我分啊!!!

#include <stdlibh>

#include <stdioh>

#include <stringh>

#define MAXN 35

#define MAX_NAME 256

typedef struct student //学生信息

{

int no;

char name[MAX_NAME];

double english;

double math;

double Programming;

double mark_ave;

double mark_tot;

} STUDENT;

/-----------输入信息子程序---------/

void input(STUDENT data, int len)

{

int no;

putchar('\n');

printf("%s\n", "请输入新的记录,如果需要退出当前菜单请输入0");

printf("%s\n", "格式:\n学号\n");

printf("%s\n", "姓名 英语 数学 C语言");

putchar('\n');

scanf("%d", &no);

while(no != 0) {

data[len]no = no;

scanf("%s %lf %lf %lf", data[len]name, &data[len]english, &data[len]math,&data[len]Programming);

data[len]mark_ave=(data[len]english+data[len]math+data[len]Programming)/30;

data[len]mark_tot=data[len]english+data[len]math+data[len]Programming;

(len)++;

scanf("%d", &no);

}

}

/---------------输出信息子程序---------------/

void output(STUDENT data, int len)

{

int i;

system("cls");

printf("%8s", "学号");

printf("%8s", "姓名");

printf("%8s", "英语");

printf("%8s", "数学");

printf("%10s", "C语言");

printf("%12s", "平均分");

printf("%10s", "总分");

putchar('\n');

for (i =0; i < 80; i++)

putchar('=');

putchar('\n');

for (i = 0; i< len; i++)

{

printf("%8d", data[i]no);

printf("%8s", data[i]name);

printf("%81lf", data[i]english);

printf("%81lf", data[i]math);

printf("%101lf", data[i]Programming);

printf("%121lf", data[i]mark_ave);

printf("%101lf", data[i]mark_tot);

putchar('\n');

}

for (i =0; i < 80; i++)

putchar('=');

putchar('\n');

printf("按回车键继续");

getchar();

getchar();

}

/--------------------搜索子程序-----------------------/

void find(STUDENT data, int len)

{

int find_no, result ;

int i;

lab: result=0;

printf("%s\n", "请输入需要查找的学生的学号,退出当前菜单请输入 -1");

scanf("%d", &find_no);

if (find_no == -1) return; /exit the fine sub program/

while( data[result]no != find_no && result < len) result ++;

if (result >= len ) {

printf("%s\n", "未查询到相关信息");

goto lab;

}

else {

system("cls");

printf("%s\n", "查询信息如下:");

for (i =0; i < 80; i++)

putchar('=');

putchar('\n');

printf("%8s", "学号");

printf("%8s", "姓名");

printf("%8s", "英语");

printf("%8s", "数学");

printf("%10s", "C语言");

printf("%12s", "平均分");

printf("%10s", "总分");

putchar('\n');

printf("%8d", data[result]no);

printf("%8s", data[result]name);

printf("%81lf", data[result]english);

printf("%81lf", data[result]math);

printf("%101lf", data[result]Programming);

printf("%121lf", data[result]mark_ave);

printf("%101lf", data[result]mark_tot);

putchar('\n');

for (i =0; i < 80; i++)

putchar('=');

putchar('\n');

goto lab;

}

}

/-----------------插入子程序-------------/

void insert(STUDENT data, int len)

{

int no, pos;

double english, math, Programming, mark_ave, mark_tot;

int i;

char name[MAX_NAME];

lab: printf("%s\n", "输入新的记录,退出当前菜单请输入-1");

printf("%s\n", "格式:学号");

printf("%s\n", " 姓名 英语 数学 C语言");

scanf("%d", &no);

if (no == -1) return;

data[len]no = no;

scanf("%s %lf %lf %lf", name, &english, &math, &Programming);

mark_ave=(english+math+Programming)/30;

mark_tot=english+math+Programming;

pos = 0;

while ((data[pos]mark_ave < mark_ave) && (pos < len) )

pos ++;

for (i = len-1; i >= pos; i--)

data[i+1] = data[i];

data[pos]no = no;

strcpy(data[pos]name, name);

data[pos]english = english;

data[pos]math = math;

data[pos]Programming = Programming;

data[pos]mark_ave = mark_ave;

data[pos]mark_tot = mark_tot;

(len)++;

goto lab;

}

/-------------删除子程序--------------/

void delete_item(STUDENT data, int len)

{

int no, i, pos;

lab: pos=0;

printf("%s\n", "输入需要删除的学生的学号,退出当前菜单请输入-1");

scanf("%d", &no);

if (no == -1) return;

while( (data[pos]no != no) && (pos < len) ) pos = pos +1;

if (pos >= len) {

printf("%s\n", "未找到需要删除的学生");

goto lab;

}

else {

for (i = pos+1;i < len; i++)

data[i-1] = data[i];

len = len -1;

if (len == 0) {

printf("%s\n", "没有任何记录,请按回车键返回");

getchar();

getchar();

return;

}

goto lab;

}

}

/---------------显示信息子程序------------/

void paint()

{

int i;

system("cls");

printf(" 学生成绩信息管理系统\n");

printf(" 西安石油大学 ------张瑞\n");

for (i = 0; i < 80; i++)

putchar('=');

putchar('\n');

printf(" 1 输入信息\n");

printf(" 2 输出信息\n");

printf(" 3 按学号查找\n");

printf(" 4 插入\n");

printf(" 5 按学号删除\n");

printf(" 0 退出\n");

for (i = 0; i<= 79; i++)

putchar('=');

putchar('\n');

printf("%s\n", "请输入各 *** 作对应的序号:");

}

/-----------主程序--------------/

void print(STUDENT data, int len){

int i = 0;

FILE fp;

fp =fopen("f:\\学生信息表txt","w+");

fprintf(fp, " 学生成绩信息表\n");

fprintf(fp, " 学号");

fprintf(fp, " 姓名");

fprintf(fp, " 英语");

fprintf(fp, " 数学");

fprintf(fp, " c语言");

fprintf(fp, " 平均分");

fprintf(fp, " 总分\n");

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

fprintf(fp,"%8d",data[i]no);

fprintf(fp,"%8s",data[i]name);

fprintf(fp,"%81lf",data[i]english);

fprintf(fp,"%81lf",data[i]math);

fprintf(fp,"%101lf",data[i]Programming);

fprintf(fp,"%121lf",data[i]mark_ave);

fprintf(fp,"%101lf\n",data[i]mark_tot);

}

fclose(fp);

}

void main()

{

STUDENT data[MAXN];

int len = 0;

char ctrl_ch;

paint();

scanf("%c", &ctrl_ch);

while (ctrl_ch != '0')

{

switch(ctrl_ch)

{

case '1':

input(data, &len);

break;

case '2':

print(data,&len);

output(data, len);

break;

case '3':

find(data, len);

break;

case '4':

insert(data, &len);

break;

case '5':

delete_item(data, &len);

break;

default:

if (ctrl_ch != '\n') printf("%s\n", "输入错误!");

break;

}

if (ctrl_ch != '\n') paint();

scanf("%c", &ctrl_ch);

}

}

高校的选班/选课管理,相信在当今社会环境下,大家都不会通过手动分班,或者使用一个随机软件随机分配,更多的是要参考学生意愿,在根据学校安排合理实施选班选课 *** 作。说的复杂其实最重要的是要有针对性的选班选课管理软件,就拿我们目前使用的排控通系统来说的,针对高校选班选课管理功能全面, *** 作简便,还是值得使用的。

C#连接Access程序代码:

usingSystemData;

usingSystemDataOleDb;

stringstrConnection="Provider=MicrosoftJetOleDb40;";

strConnection+=@"DataSource=C:\BegASPNET\Northwindmdb";

OleDbConnectionobjConnection=newOleDbConnection(strConnection);

objConnectionOpen();

objConnectionClose();

解释:

C#连接Access数据库需要导入额外的命名空间,所以有了最前面的两条using命令,这是必不可少的!

strConnection这个变量里存放的是连接数据库所需要的连接字符串,他指定了要使用的数据提供者和要使用的数据源。

“Provider=MicrosoftJetOleDb40;”是指数据提供者,这里使用的是Microsoft

Jet引擎,也就是Access中的数据引擎,aspnet就是靠这个和Access的数据库连接的。

“Data

Source=C:\BegASPNET\Northwindmdb”是指明数据源的位置,他的标准形式是“Data Source=MyDrive:MyPath\MyFileMDB”。

#include<stdioh>

#include<stdlibh>

int N1,N2,kk1,kk2,kk3;

struct couse head1;

struct student head2;

struct couse//课程信息结构体

{

int num1;

char name1[20];

int score;

int nelepeo;//课程已选人数

int Melepeo;//课程人数上限

struct couse next;

};

struct student//学生信息结构体

{

int num2;

char name2[20];

int nelenum[50];//已选课程编号

int nelen;//已选课程数量

struct student next;

};

void Ms()

{

for(kk1=0;kk1<1100;kk1++)

for(kk2=0;kk2<1200;kk2++)

for(kk3=0;kk3<1200;kk3++);

}

void keyboardc()//录入课程子函数(从键盘录入)

{

struct couse p1,p2;

N1=0;

p1=p2=(struct couse)malloc(sizeof(struct couse));

printf("课程编号\t课程名称\t学分\t课程人数上限\n");

scanf("%d%s%d%d",&p1->num1,p1->name1,&p1->score,&p1->Melepeo);

p1->nelepeo=0;

head1=NULL;

while(p1->num1!=0)

{

N1=N1+1;

if(N1==1)head1=p1;

else p2->next=p1;

p2=p1;

p1=(struct couse )malloc(sizeof(struct couse));

scanf("%d%s%d%d",&p1->num1,p1->name1,&p1->score,&p1->Melepeo);

p1->nelepeo=0;

}

p2->next=NULL;

}

void filec()//录入键盘子函数(从文件录入)

{

FILE fp;

char filepath[20];

struct couse p1,p2;

N1=0;

printf("输入要读入的文件路径:");

getchar();

gets(filepath);

if((fp=fopen(filepath,"r"))==NULL)

{

printf("找不到%s文件!\n",filepath);

exit(0);

}

p1=p2=(struct couse)malloc(sizeof(struct couse));

fscanf(fp,"%d%s%d%d%d",&p1->num1,p1->name1,&p1->score,&p1->nelepeo,&p1->Melepeo);

head1=NULL;

while(!feof(fp))

{

N1=N1+1;

if(N1==1)head1=p1;

else p2->next=p1;

p2=p1;

p1=(struct couse )malloc(sizeof(struct couse));

fscanf(fp,"%d%s%d%d%d",&p1->num1,p1->name1,&p1->score,&p1->nelepeo,&p1->Melepeo);

}

p2->next=NULL;

}

void inputc()//录入课程主函数

{

int i;

printf("\t\t\t录入课程信息\n");

printf("\n1从键盘录入\n");

printf("2从文件录入\n");

printf("3返回主菜单\n");

printf("请选择(1~3):\n");

scanf("%d",&i);

switch(i)

{

case(1):keyboardc();break;

case(2):filec();break;

case(3):break;

}

}

void insertc(struct couse incouse)//课程管理子函数(增加课程)

{

struct couse p0,p1,p2;

p1=head1;

p0=incouse;

if(head1==NULL)

{

head1=p0;

p0->next=NULL;

}

else

{

while((p0->num1 > p1->num1) && (p1->next!=NULL))

{

p2=p1;

p1=p1->next;

}

if(p0->num1 <= p1->num1)

{

if(head1==p1) head1=p0;

else p2->next=p0;

p0->next=p1;

}

else

{

p1->next=p0;

p0->next=NULL;

}

}

N1=N1+1;

}

void delc(int num1)//课程管理子函数(删除课程)

{

struct couse p1,p2;

if(head1==NULL)

{

printf("\n没有课程,无法删除!\n");

goto end;

}

p1=head1;

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

{

p2=p1;

p1=p1->next;

}

if(num1==p1->num1)

{

if(p1==head1) head1=p1->next;

else p2->next=p1->next;

printf("已删除该编号课程!\n");

N1=N1-1;

}

else printf("无该编号的课程!\n");

end:;

}

void managementc()//课程管理主函数

{

struct couse incouse;

int i,num1;

printf("\t\t\t课程管理\n");

printf("1新增课程\n");

printf("2删除课程\n");

printf("3返回主菜单\n");

printf("请选择(1~3):\n");

scanf("%d",&i);

switch(i)

{

case(1):

{

incouse=(struct couse )malloc(sizeof(struct couse));

printf("课程编号\t课程名称\t学分\t课程人数上限\n");

scanf("%d%s%d%d",&incouse->num1,incouse->name1,&incouse->score,&incouse->Melepeo);

incouse->nelepeo=0;

insertc(incouse);

break;

}

case(2):

{

printf("请输入要删除课程的编号:\n");

scanf("%d",&num1);

delc(num1);

break;

}

case(3):break;

}

}

void keyboards()//录入学生信息子函数(从键盘录入)

{

int i;

struct student p1,p2;

N2=0;

p1=p2=(struct student )malloc(sizeof(struct student));

printf("学生学号\t学生姓名\n");

scanf("%d%s",&p1->num2,p1->name2);

p1->nelen=0;

for(i=0;i<20;i++) p1->nelenum[i]=0;

head2=NULL;

while(p1->num2!=0)

{

N2=N2+1;

if(N2==1)head2=p1;

else p2->next=p1;

p2=p1;

p1=(struct student )malloc(sizeof(struct student));

scanf("%d%s",&p1->num2,p1->name2);

p1->nelen=0;

for(i=0;i<20;i++) p1->nelenum[i]=0;

}

p2->next=NULL;

}

void files()//录入学生信息子函数(从文件录入)

{

int i=0;

FILE fp;

char filepath[20];

struct student p1,p2;

N2=0;

printf("输入要读入的文件路径:");

getchar();

gets(filepath);

if((fp=fopen(filepath,"r"))==NULL)

{

printf("找不到%s文件!\n",filepath);

exit(0);

}

p1=p2=(struct student)malloc(sizeof(struct student));

fread(p1,sizeof(struct student),1,fp);

head2=NULL;

while(!feof(fp))

{

i=0;

N2=N2+1;

if(N2==1)head2=p1;

else p2->next=p1;

p2=p1;

p1=(struct student )malloc(sizeof(struct student));

fread(p1,sizeof(struct student),1,fp);

}

p2->next=NULL;

}

void inputs()//录入学生信息主函数

{

int i;

printf("\t\t\t录入学生信息\n");

printf("\n1从键盘录入\n");

printf("2从文件录入\n");

printf("3返回主菜单\n");

printf("请选择(1~3):\n");

scanf("%d",&i);

switch(i)

{

case(1):keyboards();break;

case(2):files();break;

case(3):break;

}

}

void inserts(struct student incouse)//学生信息管理子函数(填加学生信息)

{

struct student p0,p1,p2;

p1=head2;

p0=incouse;

if(head2==NULL)

{

head2=p0;

p0->next=NULL;

}

else

{

while((p0->num2 > p1->num2) && (p1->next!=NULL))

{

p2=p1;

p1=p1->next;

}

if(p0->num2 <= p1->num2)

{

if(head2==p1) head2=p0;

else p2->next=p0;

p0->next=p1;

}

else

{

p1->next=p0;

p0->next=NULL;

}

}

N2=N2+1;

}

void dels(int num2)//学生信息管理子函数(删除学生信息)

{

struct student p1,p2;

if(head2==NULL)

{

printf("\n没有该学生信息,无法删除!\n");

goto end;

}

p1=head2;

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

{

p2=p1;

p1=p1->next;

}

if(num2==p1->num2)

{

if(p1==head2) head2=p1->next;

else p2->next=p1->next;

printf("已删除该学生信息!\n");

N2=N2-1;

}

else printf("无该学号的学生!\n");

end:;

}

void managements()//学生信息管理主函数

{

struct student incouse;

int i,num2;

printf("\t\t\t学生信息管理\n");

printf("1新增学生信息\n");

printf("2删除学生信息\n");

printf("3返回主菜单\n");

printf("请选择(1~3):\n");

scanf("%d",&i);

switch(i)

{

case(1):

{

incouse=(struct student )malloc(sizeof(struct student));

incouse->nelen=0;

incouse->nelenum[0]=0;

printf("学生学号\t学生姓名\n");

scanf("%d%s",&incouse->num2,incouse->name2);

inserts(incouse);

break;

}

case(2):

{

printf("请输入要删除学生的学号:\n");

scanf("%d",&num2);

dels(num2);

break;

}

case(3):break;

}

}

void elect(struct student s)//选课

{

struct couse p;

int num1,i;

printf("请输入要选课的编号:\n");

scanf("%d",&num1);

for(i=0;s->nelenum[i]!=0;i++);

s->nelenum[i]=num1;

(s->nelen)++;

p=head1;

while(p->num1!=num1) p=p->next;

(p->nelepeo)++;

}

void cheak()//学生选课子函数(查询可选课程)

{

char e;

struct couse c;

struct student s;

int num2,i,j=0,t=0;

printf("请输入你的学号:");

scanf("%d",&num2);

s=head2;

while(s->num2!=num2 && s->next!=NULL) s=s->next;

if(s->num2!=num2)

{

printf("不存在你的信息,请进入主菜单录入你的信息!\n");

goto end;

}

c=head1;

printf("你的可选课程编号:\n");

while(c!=NULL)

{

for(t=0,i=0;s->nelenum[i]!=0;i++)

{

if(c->num1==s->nelenum[i]) t=1;

}

if(t==0 && (c->nelepeo!=c->Melepeo))

{

printf("%d\n",c->num1);

j++;

}

c=c->next;

}

if(j==0)

{

printf("你已选完所有课程,无法再多选!\n");

goto end;

}

printf("选课(y/n):\n");

getchar();

e=getchar();

i=0;

while(e=='y')

{

elect(s);

printf("继续选课(y/n):\n");

getchar();

e=getchar();

}

end:;

}

void back(struct student p)//退课

{

struct couse p1;

int num1,i,j;

printf("请输入你要退掉的课程编号:\n");

scanf("%d",&num1);

p1=head1;

while(p1->num1!=num1) p1=p1->next;

for(i=0;p->nelenum[i]!=num1;i++);

for(j=i;p->nelenum[j]!=0;j++) p->nelenum[j]=p->nelenum[j+1];

p->nelenum[--j]=0;

(p1->nelepeo)--;

printf("退课成功!\n");

}

void hcheak()//学生选课子函数(查询已选课程)

{

char c;

struct couse p0;

struct student p;

int num2,i,f=0;

printf("请输入学号:\n");

scanf("%d",&num2);

p=head2;

while(p->num2!=num2 && p!=NULL) p=p->next;

if(p==NULL)

{

printf("不存在你的信息,请回主菜单录入信息:\n");

goto end;

}

printf("已选课程编号:\n");

if(p->nelenum[0]==0)

{

printf("你还没选课!\n");

goto end;

}

for(i=0;p->nelenum[i]!=0;i++)

{

printf("%d\n",p->nelenum[i]);

p0=head1;

while(p0->num1!=p->nelenum[i]) p0=p0->next;

f=f+p0->score;

}

printf("总学分:%d\n",f);

printf("是否进行退课(y/n)");

getchar();

c=getchar();

while(c=='y')

{

back(p);

printf("继续退课(y/n)");

getchar();

c=getchar();

(p->nelen)--;

}

end:;

}

void elective()//学生选课主函数

{

int i;

printf("\t\t\t学生选课\n");

printf("1查询可选课程\n");

printf("2查询已选课程\n");

printf("3返回主菜单\n");

printf("请输入(1~3):\n");

scanf("%d",&i);

switch(i)

{

case(1):cheak();break;

case(2):hcheak();break;

case(3):break;

}

}

void listc()//输出课程信息

{

struct couse p;

p=head1;

printf("课程编号 课程名称 学分 课程已选人数 课程人数上限\n");

while(p!=NULL)

{

printf("%-8d%10s%6d%8d%12d\n",p->num1,p->name1,p->score,p->nelepeo,p->Melepeo);

p=p->next;

}

}

void lists()//输出学生信息

{

struct student p;

p=head2;

printf("学生学号 学生姓名 已选课程数量\n");

while(p!=NULL)

{

printf("%-4d %10s %6d\n",p->num2,p->name2,p->nelen);

p=p->next;

}

}

void intoc()//存储课程信息

{

FILE fp;

struct couse p;

char filepath[30];

printf("输入课程信息要保存的文件路径:");

getchar();

gets(filepath);

if((fp=fopen(filepath,"w"))==NULL)

{

printf("\n保存失败!");

exit(0);

}

p=head1;

while(p!=NULL)

{

fprintf(fp,"%d %s %d %d %d\n",p->num1,p->name1,p->score,p->nelepeo,p->Melepeo);

p=p->next;

}

fclose(fp);

printf("课程信息已保存在%s中!\n",filepath);

}

void intos()//存储学生信息

{

FILE fp;

struct student p;

char filepath[30];

printf("输入学生信息要保存的文件路径:");

getchar();

gets(filepath);

if((fp=fopen(filepath,"w"))==NULL)

{

printf("\n保存失败!");

exit(0);

}

p=head2;

while(p!=NULL)

{

fwrite(p,sizeof(struct student),1,fp);

p=p->next;

}

fclose(fp);

printf("学生信息已保存在%s中!\n",filepath);

}

void into()//存储信息

{

int i;

printf("1存储课程信息\n");

printf("2存储学生信息\n");

printf("3返回主菜单\n");

printf("请输入(1~3)\n");

scanf("%d",&i);

switch(i)

{

case(1):intoc();break;

case(2):intos();break;

case(3):break;

}

}

void store()//信息主函数

{

int i;

printf("\t\t系统信息查看及存储\n");

printf("1查看课程信息\n");

printf("2查看学生信息\n");

printf("3存储信息\n");

printf("4返回主菜单\n");

printf("请输入(1~4):\n");

scanf("%d",&i);

switch(i)

{

case(1):listc();break;

case(2):lists();break;

case(3):into();break;

case(4):break;

}

}

int main()//主函数

{

int i;

start:

printf("\n\t\t\t欢迎使用学生选课系统!\n");

printf("菜单:\n");

printf("1录入课程信息\n");

printf("2课程管理\n");

printf("3录入学生信息\n");

printf("4学生信息管理\n");

printf("5学生选课\n");

printf("6系统信息查看及存储\n");

printf("7退出系统\n");

printf("\n请输入菜单选项(1~7):\n");

scanf("%d",&i);

if(i<1 || i>7)

{

printf("输入错误,请重输:\n");

goto start;

}

switch(i)

{

case(1):

{

system("cls");

inputc();

goto start;

break;

}

case(2):

{

system("cls");

managementc();

goto start;

break;

}

case(3):

{

system("cls");

inputs();

goto start;

break;

}

case(4):

{

system("cls");

managements();

goto start;

break;

}

case(5):

{

system("cls");

elective();

goto start;

break;

}

case(6):

{

system("cls");

store();

goto start;

break;

}

case(7):

{

system("cls");

printf("感谢使用本系统!\n\n再见!\n");

}

}

return(0);

}

以上就是关于湘大的公共选修课怎么选啊全部的内容,包括:湘大的公共选修课怎么选啊、C语言求助 选修课需要做一个程序 叫 学生成绩管理系统 需要有 菜单 输入 输出 删除 计算 查找 排序 插入、如何对高校进行选班/选课 *** 作管理等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/10107874.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存