| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 14032 人关注过本帖, 9 人收藏
标题:游戏:消三连色(已完成)
取消只看楼主 加入收藏
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
结帖率:100%
收藏(9)
 问题点数:0 回复次数:11 
游戏:消三连色(已完成)
学业越来越繁重了,目前已进入考研模式,估计今后逛论坛的时间越来越少了!
想想当着各种版主,却从没做过题主,未为各位系统贡献过代码,有点惭愧。现利用周末,这两天断断续续做了款游戏,这是我小时候在爸爸手机上最喜欢玩的一款,后来有电脑了,改喜欢泡泡堂,就再也没看到这游戏。
该游戏类似于俄罗斯方块,游戏规则是:电脑随机出逐渐下落的三个色块,你通过左右移动该色块,尽量让横、竖、斜线上的颜色相同,当横竖斜线上相同色超过3个时,即可消色,否则色块越堆越高,堆到顶你就输了。
由于windows控制台模式,颜色方块较小,很多颜色相近的区分起来较困难,程序里对不同颜色方块都有相应的颜色号,同时为对准底部相同色,程序里还加了对准线,方便玩家游戏。先上效果图,代码在稍后贴出:
图片附件: 游客没有浏览图片的权限,请 登录注册


原本打算做游戏排名模块,没时间做了,有兴趣的自行添加!

[此贴子已经被作者于2017-4-2 09:03编辑过]

搜索更多相关主题的帖子: 俄罗斯方块 windows 泡泡堂 控制台 
2017-03-19 13:39
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:0 
先出一个和游戏无关的作业:如何用最快时间统计10亿内所有质数和?这是我在知乎上看到的题目,phython是0.5秒,有大神能用c比phython用更少时间吗?
上代码(4.1更,增加成绩存盘功能):
2018.4.3---不再公开本代码。

[此贴子已经被作者于2018-4-3 22:24编辑过]

2017-03-19 13:42
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:0 
回复 4楼 九转星河
你肯定行!加油,千万别成为码农!
2017-03-19 13:49
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:0 
回复 9楼 yangfrancis
当然有区别了:系统分析员是制定规则的,程序员是做项目的,码农就可怜了,遵循规则,做项目中的某部分,靠代码行数卖点辛苦钱,一旦让质量监测的发现用废代码(复制粘贴无用也无害代码)混钱,连码农都做不了。
2017-03-20 20:46
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:0 
回复 8楼 九转星河
求10亿内所有质数和的算法,我用了所谓最快的欧拉筛,我电脑跑了8秒(普通2.0G的酷睿2,2G内存),因此肯定不是建表。我觉得应该是用数学计算的方法,sum(10亿)=10亿*(10亿+1)/2,所有质数在奇数里,去掉一半=sum(10亿)/2 + 1,接下来就是减去所有合数了,问题是合数怎么来?大概还是要建一个4万内的质数表(4*4=16>10亿),这个表用普通筛0.0001秒即可完成,接下来我也不知道怎么办了。
2017-03-20 21:27
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:0 
今天对2楼代码的消色增加闪烁效果,还添加了音效!
关于快速求10亿内质数和,我确实有一个代码速度是0.15秒,不过我还没吃透这个算法。还是让代码再飞一会吧,期待有大神能解释透彻!附知乎亿大神的分析:

图片附件: 游客没有浏览图片的权限,请 登录注册


[此贴子已经被作者于2017-3-23 19:35编辑过]

2017-03-23 19:30
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:0 
昨天奋力玩到2700多分,居然不能存盘显摆,一怒之下,增加了成绩排行榜功能。
现在代码具备前5名成绩存盘功能,有静态校验能力,休想轻易通过修改存盘文件数据来修改排名成绩,但不支持动态校验(修改内存数据可能会得到一个虚高的成绩),修改后的代码仍然在二楼发布!
图片附件: 游客没有浏览图片的权限,请 登录注册


看来是发布快速10亿质数和的代码了,代码如下,有参透的还往不吝赐教(可调整为100内质数和单步参透)!
程序代码:
#include<stdio.h>
#include<math.h>
#include<time.h>

#define TRIM(a) ((a)>r)?(a)=2*r - n/(a) + 1:(a)=(a);
_int64 V[100000],S[100000]; // where V is the array of index, and S[i] denotes sum of primes less than i

int main()
{
    int start = clock();
    _int64 n = 1000000000,r,k;  //_int64在有的编译器里用long long替代
    r = (int)sqrt((double)n);
    for(k = 0; k < r + 1; k++)
    {
        V[k] = k;
        S[k] = (k*(k+1))/2 - 1;
    }
    for(; k < 2*r + 1;k++)
    {
        V[k] = n/(2*r - k + 1);
        S[k] = (V[k]*(V[k]+1))/2 - 1;
    }
    for(_int64 p = 2; p < r + 1; p++)
    {
        if(S[p]>S[p-1])
        { // this condition satifise only when p is prime
            _int64 sp = S[p-1],p2 = p*p;
            for(_int64 j = k-1; j > 1; j--)
            {
                if(V[j] < p2)break;
                _int64 a = V[j], b = a/p;
                TRIM(a);
                TRIM(b); // makes the indices correct
                S[a] -= p*(S[b] - sp); // sieve out the sum of composite numbers in S[a] which divided by p
            } 
        }
    }
    printf("%I64d\n",S[2*r]);
    printf("Total time is: %lf s\n",(double)(clock() - start)/1000);
    return 0;
}
2017-04-01 19:35
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:0 
首先看成绩单的数据结构:
struct
{
    char name[10];                   //姓名
    int score;                       //成绩
    long tt;                         //记录产生的时间(代码里没涉及)
    int crc;                         //crc就是用来校验的
}tempscore,scorefile[5];             //用于存储游戏成绩

校验函数:
int crc(int p)
{
    int i,j=0;
    for(i=0;scorefile[p].name[i]&&i<10;i++)j+=scorefile[p].name[i];
    j^=scorefile[p].score;
    j^=scorefile[p].tt;
    if(!scorefile[p].score)j=scorefile[p].crc;
    return j;
}

读取成绩单文件时判断校验码是否相等,如不等则说明有人修改了成绩单文件数据,该项成绩直接清零

void loadscore()
{//读取游戏成绩
    int i,j;
    FILE *f;
    for(i=0;i<5;i++)scorefile[i].score=0;
    if((f=fopen("score.dat","rb"))==NULL)return;
    fread(scorefile,sizeof(scorefile),1,f);
    fclose(f);
    for(i=0;i<5;i++)
    {
        if(crc(i)!=scorefile[i].crc)scorefile[i].score=0;   //这里判断校验码不相等的处理
    }
    sortscore();
}
2017-04-01 20:11
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:0 
回复 22楼 卢羽R
本代码只能在windows下编译器编译,不适用linux,vc、vs下一般能正常编译,其他编译器未试,建议注释掉“#include "stdafx.h"”。
2017-04-03 07:47
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:0 
回复 32楼 九转星河
这个游戏包括俄罗斯方块还有贪吃蛇,让计算机自动走的算法相对简单;但那个16字的ai有点难,我都想不出用什么算法。
2017-06-09 19:56
快速回复:游戏:消三连色(已完成)
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.014815 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved