资源描述
精品文档
(4) 创新能力薄弱
加拿大beadworks公司就是根据年轻女性要充分展现自己个性的需求,将世界各地的珠类饰品汇集于“碧芝自制饰品店”内,由消费者自选、自组、自制,这样就能在每个消费者亲手制作、充分发挥她们的艺术想像力的基础上,创作出作品,达到展现个性的效果
我们长期呆在校园里,没有工作收入一直都是靠父母生活,在资金方面会表现的比较棘手。不过,对我们的小店来说还好,因为我们不需要太多的投资。
附件(一):
朋友推荐□ 宣传广告□ 逛街时发现的□ 上网□
市场环境所提供的创业机会是客观的,但还必须具备自身的创业优势,才能使我们的创业项目成为可行。作为大学生的我们所具有的优势在于:
在上海, 随着轨道交通的发展,地铁商铺应运而生,并且在重要商圈已经形成一定的气候,投资经营地铁商铺逐渐为一大热门。在人民广场地下的迪美购物中心,有一家DIY自制饰品店--“碧芝自制饰品店”
(四)大学生对手工艺制品消费的要求
营销调研课题
附件(一):青岛理工大学
《C语言程序设计》
题目 C语言单项选择题标准化考试系统
指导教师:
姓名:
学号:
班级:
专业:
地点:
时间: 2013-7-1 至 2013-7-5
一、内容
【设计内容】
试设计一单项选择题标准化考试系统,实现试题的录入、抽取、用户的答题、系统的自动判卷等功能。
【设计要求】
1、用文件保存试题库。(每个试题包括题干、4个备选答案、标准答案)
2、试题录入:可随时增加试题到试题库中
3、试题抽取:每次从试题库中可以随机抽出N道题(N由键盘输入)
4、答题:用户可实现输入自己的答案
5、自动判卷:系统可根据用户答案与标准答案的对比实现判卷并给出成绩。
二、上机环境
操作系统:windows.XP
开发工具: VC6.0
三、函数调用关系图
Main()
Menu()
ReadfromFile()
Answer()
createLinkedList()
Input()
InsertNode()
WritetoFile()
Output()
TorF()
图1 函数调用关系图
四、各函数功能说明
1.main() 主函数
2.Menu() 菜单函数
3.void Answer(int n,TEST * sp) 答题函数
4.void Output(TEST* ,int i) 输出第n道题题目
5.int TorF(TEST *sp,char m) 判卷函数
6.void Input(TEST *) 题目录入函数
7.void ReadfromFile(TEST* sp) 从文件中读取题目信息
8.TEST * createLinkedList(TEST*sp) 创建链表
9.TEST* InsertNode(TEST *head, TEST*s) 插入题目函数
10.void WritetoFile(TEST* head) 保存到文件
五、流程图
六、程序运行效果图
1.初始界面
2.随机抽题
3.答题并判卷
4.插入试题
5.保存到文件
七、总结
通过这短短5天的时间,学到了许多东西,尤其是对链表及文件的使用。在这之前对于链表和文件的使用还不是特别明白,现在已经可以较为熟练的应用它们。对结构体数组的使用也更加清晰了。
在做单项选择题标准化考试系统时,碰到的第一个问题就是如何从文件里读取数据,为了解决这个问题,我细心的研究了老师给的课件,以及之前写过的学生成绩管理系统V6.0,最终解决了这个问题。碰到的第二个问题是,如何让编译器随机抽取的题目不重复,通过认真思考算法,最终得出了一个较为合理的算法。第三个问题是,链表的使用,在做“插入试题”这一块的函数时,经常出现编译错误的提示,仔细阅读编译器提供的错误信息,并对程序进行修改,最后也成功解决了这一个问题。
这份程序在文件的读取和保存以及链表的使用方面参考了老师给的课件,并进行修改。但是,我的程序在图形处理上基本是没有,所以界面不是特别美观。通过网络资源,学会了清屏,system(“cls”);
通过这次的课程设计,让我进一步的了解到C语言在我们日常生活中的重要性,体会到编一个对人们现实生活有用处的程序的快乐,更进一步的激发了我学习这门语言的兴趣.经过这次的训练,我相信自己以后会用更多的时间来把这门语言学好,掌握好这门必修的基础语言。
最后,在此对我的C语言老师——陈老师,表示感谢。感谢她平时认真地帮我调试程序,并耐心地解答疑点。在她的辅导下我从对C语言没有丝毫概念的程度到现在已经可以成功地写出一些比较像样的程序,是她开启了我的编程人生。
八、参考文献
[1] 邱建华.C语言程序设计教程.东软电子出版社,2009
[2] 谭浩强.C程序设计(第三版).清华大学出版社,2005
[3] 邱建华.C语言程序设计随堂实训及上机指导.东北大学出版社,2007
九、程序清单
精品文档
/*单项选择题标准化考试系统设计*/
#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
#include<time.h>
#include<string.h>
#define M 30
typedef struct test
{
char problem[300];
char option1[100];
char option2[100];
char option3[100];
char option4[100];
char key;
struct test *next;
}TEST;
Menu(); //菜单函数
void Answer(int n,TEST * sp); //答题函数
void Output(TEST* ,int i); //输出第n道题题目
int TorF(TEST *sp,char m); //判卷函数
void Input(TEST *); //录入题目
void ReadfromFile(TEST* sp); //从文件中读取题目信息
TEST * createLinkedList(TEST*sp); //创建链表
TEST* InsertNode(TEST *head, TEST*s); //插入函数
void WritetoFile(TEST* head); //保存到文件
int main(void)
{
TEST test[M];
TEST s;
TEST * head;
int item,n;
while(1)
{
Menu();
scanf("%d",&item);
ReadfromFile(&test);
switch(item)
{
case 1:
printf("请输入答题数:");
scanf(" %d",&n);
Answer(n,&test);
break;
case 2: system("cls");
Input(&s);
head=createLinkedList(&test);
head=InsertNode(head,&s);
break;
case 3:system("cls");
WritetoFile(head);
break;
case 4:exit(0);
break;
default:printf("输入有误!请重新输入。\n");
}
}
}
//菜单函数
Menu()
{
printf("\n\t****************单项选择题标准化考试系统*********************\n");
printf("\t* 1.答题并判卷 *\n");
printf("\t* 2.插入试题 *\n");
printf("\t* 3.保存到文件 *\n");
printf("\t* 4.退出程序 *\n");
printf("\t*************************************************************\n");
printf("\t\t请输入选项:");
}
//答题函数
void Answer(int n,TEST* sp)
{
int i,j,score=0,num[M];
char m;
srand(time(NULL));
num[0]=rand()%(M-1)+0;
for(i=0;i<n;i++)
{
loop:srand(time(NULL)); //产生真随机数
num[i]=rand()%(M-1)+0;
for(j=i;j>=0;j--) //保证不出现重复的题目
{
if(num[j]==num[j-1]) //若抽中的题重复则重新抽题
{
goto loop;
}
}
Output(&sp[num[i]],i+1); //输出抽中的题目
printf("请输入答案:");
scanf(" %c",&m);
score+=TorF(&sp[num[i]],m); //判段用户输入的答案与标准答案是否一致
}
printf("\n你的总成绩为:%d\n",score); //输出总成绩
}
void Output(TEST *sp,int i) //输出第n道题题目函数
{
printf("(%d) ",i);
printf(" %s\n",sp->problem);
printf(" A %s \n",sp->option1);
printf(" B %s \n",sp->option2);
printf(" C %s \n",sp->option3);
printf(" D %s \n",sp->option4);
}
int TorF(TEST *sp,char m) //判卷函数
{
if(sp->key==m) //若用户输入的答案与标准答案一致,返回1
{
printf("Right!\n");
return 1;
}
else
{
printf("Wrong!\n"); //若用户输入的答案与标准答案不一致,返回0
return 0;
}
}
void Input(TEST *sp) //试题录入函数
{
printf("请输入要插入的试题信息:\n");
printf("请输入题干:\n");
scanf(" %s",sp->problem);
printf("请输入选项 A:");
scanf("%s",sp->option1);
printf("请输入选项 B:");
scanf("%s",sp->option2);
printf("请输入选项 C:");
scanf("%s",sp->option3);
printf("请输入选项 D:");
scanf("%s",sp->option4);
printf("请输入答案:");
scanf(" %c",&sp->key);
}
void ReadfromFile(TEST* sp) //文件读取函数
{
FILE * fp;
int i;
if((fp=fopen("test.txt","r")) == NULL ) //文件打开失败
{
printf("Failure to open test.txt!\n");
exit(0);
}
for(i=0;!feof(fp); i++) //文件打开成功
{
fscanf(fp," %s", sp[i].problem); //将读出的数据保存在sp变量里
fscanf(fp,"%s", sp[i].option1);
fscanf(fp,"%s", sp[i].option2);
fscanf(fp,"%s", sp[i].option3);
fscanf(fp,"%s", sp[i].option4);
fscanf(fp," %c", &sp[i].key);
}
fclose(fp); //关闭文件
}
TEST * createLinkedList(TEST*sp) //创建链表
{
int i;
TEST*head=NULL,*q=NULL,*p=NULL; //定义三个变量
for(i=0;i<M;i++)
{
p= (TEST*)malloc(sizeof(TEST)); //申请内存
p=&sp[i];
p->next=NULL;
if(i==0)
{
head=p; //链表的表头
}
else
{
q->next=p;
}
q=p;
}
return head;
}
TEST* InsertNode(TEST *head, TEST*s) //插入函数
{
int n,i;
TEST*p,*q;
p=head;
q=p->next;
printf("请输入要在哪个节点后插入题目信息:");
scanf(" %d", &n);
for(i=0;q!=NULL && n!=i+1;i++) //遍历
{
p = p->next;
q = q->next;
}
if(q == NULL)
{
printf("Not found!\n");
}
Else //插入数据
{
p->next = s;
s->next = q;
}
return head;
}
void WritetoFile(TEST*head) //保存到文件
{
FILE * fp;
TEST *q;
if((fp = fopen("student.txt","w")) == NULL ) //文件打开失败
{
printf("Failure to open file!\n");
exit(0);
}
for(q=head;q!=NULL;q=q->next) //用链表的方式将数据保存到文件
{
fprintf(fp," %s\n", q->problem);
fprintf(fp,"%s\n",q->option1);
fprintf(fp,"%s\n",q->option2);
fprintf(fp,"%s\n",q->option3);
fprintf(fp,"%s\n",q->option4);
fprintf(fp," %c\n",q->key);
}
fclose(fp); //关闭文件
}
展开阅读全文