博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
第二章
阅读量:5115 次
发布时间:2019-06-13

本文共 5081 字,大约阅读时间需要 16 分钟。

1.(1)程序花多长时间完成?

对于学生每个人不同的实际情况,程序完成的时间也不太相同。基础比较好的同学花费大概半个小时,对于初学者来说需要一个小时左右。

(2)程序量是多少?

程序量指的就是有多少行代码,也是根据对代码的熟练来判定,基础好的大概100行左右。

(3)开发过程中使用了源代码管理等工具吗?

 源代码是指一系列人类可读的计算机语言指令,使用源代码等管理工具随着年级的增高而改变,年级越高的同学使用率更高;反之则越少。

(4)完全独立完成的同学有多少个?

大部分同学是借鉴没办法自己独立完成,只有少部分同学能通过所学知识独立完成编程。

(5)程序解决实际问题吗?

主要看程序偏向什么,大部分没法解决实际问题。

(6)说明了什么?

无论在什么时候,总是会有借鉴,有好的作品完成随之就会有一部分模仿品。借鉴虽然没问题,但是要在自己会的前提下,再来借鉴。

2.你有什么编程相关的手艺?

单纯的通过老师上课所讲述的内容只是学会基础,并不能有更深层次的研究,对于编程相关的手艺一无所知,只是通过网络对于小手艺进行观看,学习。

关于贪吃蛇小游戏的C语言编程

#define N 200    #include 
#include
#include
#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
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

 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
优点:1.结构易于创建:在创建平台中立的网格结构方面。
           2.可视化编程:允许程序员重新安排这些操作。
           3.便于下载,适用于各行各业的人士学习。
缺点:1.对于一些英文无法更好的了解。
           2.插件太多,不好操作。

转载于:https://www.cnblogs.com/lgx19/p/8647717.html

你可能感兴趣的文章
poj2569
查看>>
使用pygal_maps_world.i18n中数据画各大洲地图
查看>>
sql server必知多种日期函数时间格式转换
查看>>
ListView如何获取点击单元格内容
查看>>
jQuery EasyUI 的下拉选择combobox后台动态赋值
查看>>
timeline时间轴进度“群英荟萃”
查看>>
python if else elif statement
查看>>
网络编程
查看>>
文本隐藏(图片代替文字)
查看>>
three.map.control
查看>>
java面试题
查看>>
提高码力专题(未完待续)
查看>>
IOS第17天(3,Quartz2D画板和画线)
查看>>
pair的例子
查看>>
前端框架性能对比
查看>>
@property中 retain 详解
查看>>
java8 stream初试,map排序,list去重,统计重复元素个数,获取map的key集合和value集合...
查看>>
Python爬虫个人记录(四)利用Python在豆瓣上写一篇日记
查看>>
uva 387 A Puzzling Problem (回溯)
查看>>
12.2日常
查看>>