第二章
1.(1)程序花多长时间完成?
对于学生每个人不同的实际情况,程序完成的时间也不太相同。基础比较好的同学花费大概半个小时,对于初学者来说需要一个小时左右。
(2)程序量是多少?
程序量指的就是有多少行代码,也是根据对代码的熟练来判定,基础好的大概100行左右。
(3)开发过程中使用了源代码管理等工具吗?
源代码是指一系列人类可读的计算机语言指令,使用源代码等管理工具随着年级的增高而改变,年级越高的同学使用率更高;反之则越少。
(4)完全独立完成的同学有多少个?
大部分同学是借鉴没办法自己独立完成,只有少部分同学能通过所学知识独立完成编程。
(5)程序解决实际问题吗?
主要看程序偏向什么,大部分没法解决实际问题。
(6)说明了什么?
无论在什么时候,总是会有借鉴,有好的作品完成随之就会有一部分模仿品。借鉴虽然没问题,但是要在自己会的前提下,再来借鉴。
2.你有什么编程相关的手艺?
单纯的通过老师上课所讲述的内容只是学会基础,并不能有更深层次的研究,对于编程相关的手艺一无所知,只是通过网络对于小手艺进行观看,学习。
关于贪吃蛇小游戏的C语言编程
#define N 200 #include <graphics.h> #include <stdlib.h> #include <dos.h> #define LEFT 0x4b00 #define RIGHT 0x4d00 #define DOWN 0x5000 #define UP 0x4800 #define ESC 0x011b int i,key; int score=0;/*得分*/ int gamespeed=50000;/*游戏速度自己调整*/ struct Food { int x;/*食物的横坐标*/ int y;/*食物的纵坐标*/ int yes;/*判断是否要出现食物的变量*/ }food;/*食物的结构体*/ struct Snake { int x[N]; int y[N]; int node;/*蛇的节数*/ int direction;/*蛇移动方向*/ int life;/* 蛇的生命,0活着,1死亡*/ }snake; void Init(void);/*图形驱动*/ void Close(void);/*图形结束*/ void DrawK(void);/*开始画面*/ void GameOver(void);/*结束游戏*/ void GamePlay(void);/*玩游戏具体过程*/ void PrScore(void);/*输出成绩*/ /*主函数*/ void main(void) { Init();/*图形驱动*/ DrawK();/*开始画面*/ GamePlay();/*玩游戏具体过程*/ Close();/*图形结束*/ } /*图形驱动*/ void Init(void) { int gd=DETECT,gm; initgraph(&gd,&gm,"c:\\tc"); cleardevice(); } /*开始画面,左上角坐标为(50,40),右下角坐标为(610,460)的围墙*/ void DrawK(void) { /*setbkcolor(LIGHTGREEN);*/ setcolor(11); setlinestyle(SOLID_LINE,0,THICK_WIDTH);/*设置线型*/ for(i=50;i<=600;i+=10)/*画围墙*/ { rectangle(i,40,i+10,49); /*上边*/ rectangle(i,451,i+10,460);/*下边*/ } for(i=40;i<=450;i+=10) { rectangle(50,i,59,i+10); /*左边*/ rectangle(601,i,610,i+10);/*右边*/ } } /*玩游戏具体过程*/ void GamePlay(void) { randomize();/*随机数发生器*/ food.yes=1;/*1表示需要出现新食物,0表示已经存在食物*/ snake.life=0;/*活着*/ snake.direction=1;/*方向往右*/ snake.x[0]=100;snake.y[0]=100;/*蛇头*/ snake.x[1]=110;snake.y[1]=100; snake.node=2;/*节数*/ PrScore();/*输出得分*/ while(1)/*可以重复玩游戏,压ESC键结束*/ { while(!kbhit())/*在没有按键的情况下,蛇自己移动身体*/ { if(food.yes==1)/*需要出现新食物*/ { food.x=rand()%400+60; food.y=rand()%350+60; while(food.x%10!=0)/*食物随机出现后必须让食物能够在整格内,这样才可以让蛇吃到*/ food.x++; while(food.y%10!=0) food.y++; food.yes=0;/*画面上有食物了*/ } if(food.yes==0)/*画面上有食物了就要显示*/ { setcolor(GREEN); rectangle(food.x,food.y,food.x+10,food.y-10); } for(i=snake.node-1;i>0;i--)/*蛇的每个环节往前移动,也就是贪吃蛇的关键算法*/ { snake.x[i]=snake.x[i-1]; snake.y[i]=snake.y[i-1]; } /*1,2,3,4表示右,左,上,下四个方向,通过这个判断来移动蛇头*/ switch(snake.direction) { case 1:snake.x[0]+=10;break; case 2: snake.x[0]-=10;break; case 3: snake.y[0]-=10;break; case 4: snake.y[0]+=10;break; } for(i=3;i<snake.node;i++)/*从蛇的第四节开始判断是否撞到自己了,因为蛇头为两节,第三节不可能拐过来*/ { if(snake.x[i]==snake.x[0]&&snake.y[i]==snake.y[0]) { GameOver();/*显示失败*/ snake.life=1; break; } } if(snake.x[0]<55||snake.x[0]>595||snake.y[0]<55|| snake.y[0]>455)/*蛇是否撞到墙壁*/ { GameOver();/*本次游戏结束*/ snake.life=1; /*蛇死*/ } if(snake.life==1)/*以上两种判断以后,如果蛇死就跳出内循环,重新开始*/ break; if(snake.x[0]==food.x&&snake.y[0]==food.y)/*吃到食物以后*/ { setcolor(0);/*把画面上的食物东西去掉*/ rectangle(food.x,food.y,food.x+10,food.y-10); snake.x[snake.node]=-20;snake.y[snake.node]=-20; /*新的一节先放在看不见的位置,下次循环就取前一节的位置*/ snake.node++;/*蛇的身体长一节*/ food.yes=1;/*画面上需要出现新的食物*/ score+=10; PrScore();/*输出新得分*/ } setcolor(4);/*画出蛇*/ for(i=0;i<snake.node;i++) rectangle(snake.x[i],snake.y[i],snake.x[i]+10, snake.y[i]-10); delay(gamespeed); setcolor(0);/*用黑色去除蛇的的最后一节*/ rectangle(snake.x[snake.node-1],snake.y[snake.node-1], snake.x[snake.node-1]+10,snake.y[snake.node-1]-10); } /*endwhile(!kbhit)*/ if(snake.life==1)/*如果蛇死就跳出循环*/ break; key=bioskey(0);/*接收按键*/ if(key==ESC)/*按ESC键退出*/ break; else if(key==UP&&snake.direction!=4) /*判断是否往相反的方向移动*/ snake.direction=3; else if(key==RIGHT&&snake.direction!=2) snake.direction=1; else if(key==LEFT&&snake.direction!=1) snake.direction=2; else if(key==DOWN&&snake.direction!=3) snake.direction=4; }/*endwhile(1)*/ } /*游戏结束*/ void GameOver(void) { cleardevice(); PrScore(); setcolor(RED); settextstyle(0,0,4); outtextxy(200,200,"GAME OVER"); getch(); } /*输出成绩*/ void PrScore(void) { char str[10]; setfillstyle(SOLID_FILL,YELLOW); bar(50,15,220,35); setcolor(6); settextstyle(0,0,2); sprintf(str,"score:%d",score); outtextxy(55,20,str); } /*图形结束*/ void Close(void) { getch(); closegraph(); }
BF语言介绍:
Brainfuck,是一种极小化的计算机语言,这种 语言,是一种按照"Turing complete(完整图灵机)"思想设计的语言,它的主要设计思路是:用最小的概念实现一种"简单"的语言,BrainFuck 语言只有八种符号,所有的操作都由这八种符号的组合来完成。BF基于一个简单的机器模型,除了八个指令,这个机器还包括:一个以字节为单位、被初始化为零的数组、一个指向该数组的指针(初始时指向数组的第一个字节)、以及用于输入输出的两个字节流。
Piet语言:
Piet 是一种非常深奥的编程语言,使用颜色编写代码。由David Morgan-Mar,其方案是位图,看起来像抽象艺术设计。编译指导图像周围移动,从一个连续颜色的区域下的一个“指针”。通过一个地区的指针退出时的程序进行。
编号 | 指令 | 含义 | 颜色Red | 颜色Green | 颜色Blue |
1 | start | 表示一个代码段的开始 | 0 | 0 | 0 |
2 | end | 表示一个代码段的结束 | 2 | 2 | 2 |
3 | ++(plusplus) | 将寄存器中的数加1 | 0 | 0 | 1 |
4 | --(minusminus) | 将寄存器中的数减1 | 0 | 0 | 2 |
5 | push | 将寄存器中的数写入栈中 | 0 | 1 | 1 |
6 | pop | 将栈中的数读弹出并不存入寄存器中 | 0 | 1 | 2 |
7 | in | 控制台输入一个字符到寄存器 | 0 | 2 | 1 |
8 | out | 将寄存器的字符打印到控制台 | 0 | 2 | 2 |
9 | turn |
栈顶元素与寄存器比较,如果相等则代码方向指针向前 如果大于则代码方向指针向左,如果小于则代码方向指针向右 |
1 | 0 | 1 |
10 | zero | 将寄存器中的数置零 | 1 | 0 | 0 |
11 | call | 跳转指令,以寄存器为x,以栈顶数为y,跳到图像的(x,y)位置开始执行 | 1 | 1 | 1 |
12 | add | 栈顶元素与寄存器相加,并保存在寄存器中 | 2 | 0 | 0 |
13 | sub | 栈顶元素减去寄存器,差保存在寄存器中 | 2 | 0 | 1 |
14 | mul | 栈顶元素与寄存器相乘,并保存在寄存器中 | 2 | 1 | 0 |
15 | div | 栈顶元素除以寄存器,商保存在寄存器中 | 2 | 1 | 1 |
3.一。写程序的人(coder):这种类型的人单纯的只是为了工作、功课、任务而写程序,虽然职务名称叫做工程师,但是写程序对他们来说只是获取成绩、金钱的工具,写程序对他们 来说枯燥无味,但为了生活,他们继续产出他们的程序码。他们喜欢简单的任务,最好是一看到就知道要怎么做,最好有开源的程序码可以直接套用。只要他们的程 序可以过关,他们就开心的回家睡觉去了,一秒钟都不想再看代码。这些人就是把工作当成杂事或是职业,而不是志业,每天早上去上班,因为必需要去,而不是自己想去,去了之后就开始期待领薪水,期待放假。而让自己做好的主要工作动机都是外部因素,升迁、加薪、权力。把工作看成志业的人,会认为工作本身就是他的目的,动机来自于内在因素,觉得有贡献,觉得在实现自我。二。有目标而写程序的人(hacker):这种类型的人并不是因为热爱「程序」本身而开始写程序,他们写程序是为了要达成某些目的。这些人虽然不是天生的程序高手,但是很会用别人写好的 套件去兜出一些应用,当有一个好的点子时,他们第一件事不是去想:「我本身不是学这个的,我要怎么样才能找到别人来帮我做⋯⋯」他们会去找既有的资源架 构,尝试做出原型 (Prototype),有时候虽然做出来虽然有点破 (像是下图右方的机器人),但他们乐在其中,并且常常不眠不休的写程序。这正是我想说的,Hacking 是一种精神,拥有 Hacking 精神的人就是 Hacker。4.java开发工具:java extension pack