实训报告应用电子 C语言优秀大作业-种地要浇水II-附赠实验报告(有界面可运行)

小编 2024-10-11 电子技术 23 0

C语言优秀大作业-种地要浇水II-附赠实验报告(有界面可运行)

课程大作业 报告

课程名称 程序设计

题目名称_ 种地要浇水_______

学生学院

专业班级________________________

姓名学号________________________

________________________

指导教师

年 月 日

1.主要工作及意义

描述你在本题目中所做的工作。

本人比较想做一个游戏类的程序,因此在确定这一思想学习了c语言的BGI图形库,键盘操作库conio.h,时间函数库time.h,连接操作系统API的windows.h,以及常规字符库string.h,在设计此款游戏之前我先查阅了CSDN上用c语言设计的打飞机和坦克大战等有键盘操作游戏的整体思路并由此而衍生了我的作品。本人在设计此款游戏时参考了c语言书中中随机生成数字的算法并衍生应用到整体设计图案的算法上。本人完成了重原始设计到最后的作品规则修改数据测试的整体过程,最后生成了EXE可执行文件,运行后可根据规则正常游戏保证代码的健壮性。其中自己也编写过一些数据进行测试保证了游戏规则的可行性。

2.系统详细设计

确定选题后上网找到可用图标的图片

利用变量记录金币和选中的田地块int coin = 10; // 初始10枚金币(赢赚5,输或重置扣2,旋跳扣3,金币不足不允许重置旋跳,仅允许输且金币归零)int row = 0, col = 0; // 当前选中的田地块设计图片随机生成的函数,利用随机生成数字的算法并衍生应用到整体设计图案的算法上,设计每一步变化的图片细节,形成11种情况的图片设计//11种随机数对应的11种情况:// 1╋ 2┫ 3┣ 4┻ 5┳ 6┏ 7┗ 8┓ 9┛ 10━ 11┃//0空,1、2, 3、4, 5、6, 7、8, 9、10, 11、12, 13、14, 15、16, 17、18, 19、20, 21、22//上一行每种类型前者为有水(奇数),后者为干涸(偶数),是对11种情况的细化bool tongchang[11][4] = {//上下左右通畅情况(针对以上11种情况的田地块)1,1,1,1,/* ╋ */ 1,1,1,0,/* ┫ */1,1,0,1,/* ┣ */ 1,0,1,1,/* ┻ */0,1,1,1,/* ┳ */ 0,1,0,1,/* ┏ */1,0,0,1,/* ┗ */ 0,1,1,0,/* ┓ */1,0,1,0,/* ┛ */ 0,0,1,1,/* ━ */1,1,0,0/* ┃ */};int map[6][6]={0};//0到22,保存6*6的田地信息设计每一步深沉的图片加载函数,设计重加载到每一步不同的图片及图片分块,细化到23种情况对应图片IMAGE img[23];//加载图片void load_field_img(){IMAGE field_img;//用于加载竖条图loadimage(&field_img, ".\\img\\img1.jpg", 0, 0, false );SetWorkingImage(&field_img);int height = field_img.getheight() / 9;int width = field_img.getwidth();getimage(&img[0], 0, 0 * height, width, height); // 空地getimage(&img[22], 0, 1 * height, width, height); // 干涸┃getimage(&img[16], 0, 2 * height, width, height); // 干涸┓getimage(&img[4], 0, 3 * height, width, height); // 干涸┫getimage(&img[1], 0, 4 * height, width, height); // 有水╋getimage(&img[17], 0, 5 * height, width, height); // 有水┛getimage(&img[21], 0, 6 * height, width, height); // 有水┃getimage(&img[7], 0, 7 * height, width, height); // 有水┻getimage(&img[2], 0, 8 * height, width, height); // 干涸╋SetWorkingImage();//以上9种靠直接加载图片分块,其余14种靠逆时针旋转前9种获取rotateimage(&img[3], &img[7], PI / 2); // 有水┫rotateimage(&img[5], &img[7], 3 * PI / 2); // 有水┣rotateimage(&img[6], &img[4], PI); // 干涸┣rotateimage(&img[8], &img[4], 3 * PI / 2); // 干涸┻rotateimage(&img[9], &img[7], PI); // 有水┳rotateimage(&img[10], &img[4], PI / 2); // 干涸┳rotateimage(&img[11], &img[17], PI); // 有水┏rotateimage(&img[12], &img[16], PI / 2); // 干涸┏rotateimage(&img[13], &img[17], 3 * PI/2); // 有水┗rotateimage(&img[14], &img[16], PI); // 干涸┗rotateimage(&img[15], &img[17], PI / 2); // 有水┓rotateimage(&img[18], &img[16], 3 * PI/2); // 干涸┛rotateimage(&img[19], &img[21], PI / 2); // 有水━rotateimage(&img[20], &img[22], PI / 2); // 干涸━}设计水渠缓冲区函数,包括初始水渠缓冲区,变化水渠缓冲区,显示水渠缓冲区int sq_buff[4];//水渠缓冲区(数组队列,数组尾先入先出,存11种随机数)void init_sq_buff()//初始水渠缓冲区{for (int i=3;i>=0;i--){sq_buff[i]=my_rand();}}int get_sq_buff()//变化水渠缓冲区{int result=sq_buff[3];for (int i=2;i>=0;i--){sq_buff[i+1]=sq_buff[i];}sq_buff[0]=my_rand();return result;}void print_sq_buff()//显示水渠缓冲区{//左上31,35;31,99;31,162;31,233;putimage(31,35,&img[sq_buff[0]*2]);putimage(31,99,&img[sq_buff[1]*2]);putimage(31,162,&img[sq_buff[2]*2]);putimage(31,233,&img[sq_buff[3]*2]);}用函数表示11种情况旋转映射(先逆后顺)int rotated_list[][2]={-1,-1,//无意义占位1,1, 5,4,4,5, 2,3,3,2, 7,8,9,6, 6,9,8,7, 11,11,10,10};设计水渠通水情况的递归判断,之前务必先让所有水渠干涸的逻辑void judge(int i,int j,int direction)//参数为map的行和列、以及水源自哪个方向而来:0上1下2左3右{if (i<0 || j<0 || map[i][j]==0 || map[i][j]%2==1){//递归结束条件:越界、无渠、已经有水return ;}int type=(map[i][j]+1)/2;//得到1到11的数字,对应类型如上if (tongchang[type-1][direction])//本块与水源相通{map[i][j]-=1;//本块注水//依次向本块的其它三个方向递归for (int n=0;n<4;n++){if (n==direction){continue ;//跳过水源方向}if (tongchang[type-1][n]==1)//其它三个方向的某一个通畅{if (n==0)//上通畅{judge(i-1,j,1);//下一个递归块水源自下}elseif (n==1)//下通畅{judge(i+1,j,0);//下一个递归块水源自上}elseif (n==2)//左通畅{judge(i,j-1,3);//下一个递归块水源自右}elseif (n==3)//右通畅{judge(i,j+1,2);//下一个递归块水源自左}}}}else {return ;}}//总的调用以上void check_water(){//先让所有水渠干涸for (int i=0;i<6;i++){for (int j=0;j<6;j++){if (map[i][j]%2==1)//该块有水map[i][j]+=1;}}//再递归判断judge(0,3,0);}输出金币数函数的设计//数字转字符串:智能判断位数//计算a的b次方int pw(int a,int b){int result=1;for (int i=0;i<b;i++)result*=a;return result;}void int_str(char str[11],int num,int jinzhi){if (num==0){str[0]='0';str[1]='\0';return ;}int i=0,temp;while (num>=pw(jinzhi,i))i++;//此时需分配i+1位(含'\0')长度字符串str[10]='\0';for (int n=i;n<10;n++){str[n]=' ';}for (int k=i-1;k>=0;k--){temp=num%jinzhi;//当前最后一位num/=jinzhi;if (temp>=10 && temp<=15)temp+=('A'-10);elseif (temp>=0 && temp<=9)temp+='0';else //异常处理{str[0]='\0';return ;}str[k]=(char )temp;}}void print_coin(){char coin_str[11];int_str(coin_str,coin,10);setcolor(BLACK);outtextxy(552, 32, coin_str);}整体重绘田地的实现void draw_field(int i,int j)//准备工作一:i、j都是0到5的数,对应某块田地,将其画出{putimage(169+j*54,98+i*54,&img[map[i][j]]);}void draw_frame()//准备工作二:画黄色的选中框{setcolor(YELLOW);int a = col * 54, b = row * 54;rectangle(170 + a, 99 + b, 220 + a, 149 + b);rectangle(171 + a, 100 + b, 219 + a, 148 + b);rectangle(172 + a, 101 + b, 218 + a, 147 + b);}void refresh_all()//绘制所有田地块{//背景色0xCACEB7//缓冲区左上31,35;31,99;31,162;31,233;//田地左上168,97;左上右222,97;左上下168,151;右下493,422print_sq_buff();check_water();for (int i=0;i<6;i++){for (int j=0;j<6;j++){draw_field(i,j);}}draw_frame();}胜利判断void check_win(){int water_num=0;for (int i=0;i<6;i++){for (int j=0;j<6;j++){if (map[i][j]==0){return ;//还没填满呢}if (map[i][j]%2==1){water_num++;}}}if (water_num==36){string temp="完成奖励:5金币\n";int add=5;if (my_rand()%3==0){temp+="人品追加:2金币\n";add+=2;}if (row==0 && col==3){temp+="达成成就【瞬息贯通】,追加10金币\n";add+=10;}int n;bool feishui=true ;//【肥水不流外人田】成就判定for (n=0;n<6;n++){if (tongchang[ map[0][n]/2 ][0] && n!=3)//上有出口,判定失败{feishui=false ;break ;}elseif (tongchang[ map[n][0]/2 ][2])//左有出口,判定失败{feishui=false ;break ;}elseif (tongchang[ map[5][n]/2 ][1])//下有出口,判定失败{feishui=false ;break ;}elseif (tongchang[ map[n][5]/2 ][3])//右有出口,判定失败{feishui=false ;break ;}}if (feishui){temp+="达成成就【肥水不流外人田】,追加15金币\n";add+=15;}coin+=add;char str[11];int_str(str,add,10);str[3]='\0';temp+="总计:";temp+=str;temp+="金币";MessageBox(NULL,temp.c_str(),"你很有想法",MB_SYSTEMMODAL);}else {coin-=2;if (coin<=0){coin=0;MessageBox(NULL,"任务失败,钱扣至0后不会再扣","请允悲",MB_SYSTEMMODAL);}else {MessageBox(NULL,"任务失败,失去金币2","请允悲",MB_SYSTEMMODAL);}}//后续工作init_sq_buff();memset(map, 0, sizeof (int )*36);row=0,col=0;print_coin();print_sq_buff();refresh_all();FlushBatchDraw();}

11.主函数整体逻辑的调用

int main(){srand((unsigned)time(NULL));init_sq_buff();char c;// 绘图环境初始化initgraph(640, 480);load_field_img();setbkcolor(0xcaceb7);BeginBatchDraw();// 加载界面IMAGE img_main;loadimage(&img_main, _T(".\\img\\main.jpg"));putimage(0, 0, &img_main);//其他初始工作print_coin();init_sq_buff();print_sq_buff();refresh_all();FlushBatchDraw();// 扫描按键while (1){//方向键-32and(72,80,75,77)上下左右;空格32;c = _getch();if (c == -32){c = _getch();if (c == 72)//↑{if (row==0)//不能再向上continue ;else {row--;refresh_all();FlushBatchDraw();}}elseif (c == 80)//↓{if (row==5)//不能再向下continue ;else {row++;refresh_all();FlushBatchDraw();}}elseif (c == 75)//←{if (col==0)//不能再向左continue ;else {col--;refresh_all();FlushBatchDraw();}}elseif (c == 77)//→{if (col==5)//不能再向右continue ;else {col++;refresh_all();FlushBatchDraw();}}}elseif (c==32)//空格{if (map[row][col]==0){map[row][col]=get_sq_buff()*2;print_sq_buff();check_water();refresh_all();FlushBatchDraw();check_win();}else {MessageBox(NULL,"该区域已放置水渠,不可覆盖","囧",MB_SYSTEMMODAL);}}elseif (c=='R' || c=='r')//重置{if (coin>1){coin-=2;init_sq_buff();memset(map, 0, sizeof (int )*36);row=0,col=0;print_coin();print_sq_buff();refresh_all();FlushBatchDraw();}else {MessageBox(NULL,"金币不足2,不能使用该特技","囧",MB_SYSTEMMODAL);}}elseif (c=='S' || c=='s')//顺时针{if (coin>2){sq_buff[3]=rotated_list[sq_buff[3]][1];putimage(31,233,&img[sq_buff[3]*2]);coin-=3;print_coin();FlushBatchDraw();}else {MessageBox(NULL,"金币不足3,不能使用该特技","囧",MB_SYSTEMMODAL);}}elseif (c=='N' || c=='n')//逆时针{if (coin>2){sq_buff[3]=rotated_list[sq_buff[3]][0];putimage(31,233,&img[sq_buff[3]*2]);coin-=3;print_coin();FlushBatchDraw();}else {MessageBox(NULL,"金币不足3,不能使用该特技","囧",MB_SYSTEMMODAL);}}elseif (c=='T' || c=='t')//跳过一个{if (coin>2){get_sq_buff();print_sq_buff();coin-=3;print_coin();FlushBatchDraw();}else {MessageBox(NULL,"金币不足3,不能使用该特技","囧",MB_SYSTEMMODAL);}}elseif (c=='H' || c=='h')//帮助{MessageBox(NULL,"赢赚5(人品好追加2),输或重置扣2,其他特技扣3;\n金币不足不允许使用特技,输到金币0以后不另扣钱。\n特殊成就:\n【瞬息贯通】:最后放置入水口水渠,追加10金币;\n【肥水不流外人田】:水渠封闭,追加15金币。","帮助",MB_SYSTEMMODAL|MB_ICONINFORMATION);}elseif (c==27)//esc{break ;}}EndBatchDraw();closegraph();return 0;}系统测试

4.总结

4.1 技术总结

通过整体的学习我了解了c语言变量,全局变量,数组,机构体,函数,列表,头文件的意义与用法,并在此次作业中我的编程水平,算法,排错能力都得到了提升,并学会了初级小游戏的制作

4.2 心得体会

5.参考文献和资料

[1]周宇扬.C语言在游戏程序设计中的应用与研究[J].电子世界,2018(23):131.

[2]陈慧杰,郭占祥.基于C语言的五子棋游戏程序设计[J].宁波职业技术学院学报,2012,16(02):41-44.

[3]马巧梅,张丽娜.基于C语言的俄罗斯方块游戏的设计[J].微型电脑应用,2017,33(12):7-9.

[4]徐驰.基于C语言的扫雷游戏设计与实现[J].信息与电脑(理论版),2018(13):107-108+112.

教师评语和评分

教师评语:

教师评分:_____________

教师签名:

日期:

IT技术支持实习报告

实习岗位:IT技术支持实习生

实习单位:某科技公司

一、 引言

随着信息技术的快速发展,IT技术支持已成为企业不可或缺的岗位。本次实习旨在提高自己的IT技术水平和实际操作能力。

二、 实习经历

1、协助解决客户遇到的IT问题,提供技术支持和解决方案。2、学习各种IT技术和工具,了解最新的技术趋势和发展。3、参与IT项目的实施和管理,了解项目管理的基本流程和方法。

三、困难与挑战

面对各种复杂的IT问题,如何快速定位和解决问题是一个挑战。通过不断学习和实践,我逐渐提高了自己的技术水平和解决问题的能力。

四、行业思考

IT技术支持需要不断学习和更新知识储备。随着技术的不断进步,只有不断学习才能跟上时代的步伐。

五、结论与展望

IT技术支持是一个充满挑战和机遇的领域。我计划继续深入学习IT相关知识和技能,并寻找机会将所学应用到未来的工作中。

相关问答

实习 报告 中盖章怎么弄成 电子 版?

要将带盖章的纸质文档变成电子版可以用扫描仪将其扫描到电脑里,然后保存为jpG格式就可以啦,当然,现在有好多小程序文件,也可以将纸质文档变成电子版,你可以...

【电子天平操作实验 报告电子 天平的3种操作实验报告!1,直接法...

[最佳回答]电子天平实验报告实验目的1掌握电子天平的基本操作;2掌握实物称量的技术;3掌握准确、简明、规范地记录实验原始数据的方法.仪器和试剂电子天平、...

你们觉得大学的实验 报告 该花大把时间来抄吗?

大多数专业的大学生涯里,必然少不了实验课,而实验课又必然少不了实验报告,这个确实是让很多大学生感到头痛的作业。就用我自己来说吧,我大学是读医学专业的,...

系解实验 报告 怎么写?

系解实验报告常用的内容与格式如下1、实验名称以及姓名学号要用最简练的语言反映实验的内容。可写成“解剖什么”、“分析什么”等。2、实验日期和地点比...

急,求一篇大一物理演示实验 报告 !明天就要交物理演示 报告 了!...

[最佳回答]简单操作:1、闭合铝环的上跳演示将电源插座插入电源,打开电源开关,将铝环套入铁棒内按动操作开关.当开关接通则铝环高高跳起,当保持操作开关接通状...

实验 报告 一般保存多久?

1.科学数据应当在科学共同体内广泛共享;同时,应当保护知识产权、专有权和个人隐私权,防止泄露应予保密的数据。2.各学科领域关于科学数据保存期限的规定...1...

比较ksp的大小的实验总结

同类型电解质(阴阳离子个数比相等)Ksp越大溶解性越大,说明难溶物在水中的溶解能力越强;对阴阳离子个数比不同的难溶物,则必须通过计算判断,如AgCl与Fe(OH...

会计模拟实验 报告 实验流程及原理?

会计实训的基本原理是通过各单项模拟实训,了解各项经济业务仿真的原始凭证,掌握相关业务记账凭证的编制,总账与明细账的登记,资产负债表和利润表的编制,加强...

实验 报告 的小节收获感想怎么写?

就写自己在这次实验中:学到了什么知识,自己做的好的地方,做的不好的地方,以及自己有什么好的建议、心得体会等内容。就写自己在这次实验中:学到了什么知识,自...

实习成果包括哪些方面?

包括:1.实习单位的状况。2.你实习的主要内容。3.你在实习中遇到的问题。4.你对这些问题的看法及建议。实习能证明你的社会实践能力,你的个人能力才会显现...