论坛登陆 注册 教程 笑话 影视 投稿
首页 | 页界资讯 | 网络应用 | 软件应用 | 组网技术 | 网络原理 | 聊天通讯 | 网管知识 | 帮助
笑话 | 操作系统 | 注 册 表 | 编程开发 | 数 据 库 | 媒体动画 | 网页设计 | 图形图象 | 地图
论坛 | 网络安全 | 安全防范 | 服 务 器 | 硬件学堂 | 路由技术 | 搜索研究 | 站长经验 | 投稿
影院 | 教育频道 | 特色专题 | 精文荟萃 | 注 册 码 | 论坛社区 | 网站地图 | 广告服务 | 旧版
设为首页 加入收藏
当前位置:首页>>文章>>编程开发>>C/C++>>正文

原创:一个c++写的发牌程序

www.xker.com 作者: 来源:csdn 加入日期:2006-4-11 10:08:55

【问题提问、论坛交流】可以显示一,二,三,四家的牌

主要是为了训练我的牌感(记牌的能力),对有志于赌博或者桥牌事业的同志可能还有点用

编译为bd.exe,使用方法输入"bd -h"看帮助

以下是源代码(处理命令行参数的代码参考了vim):



#include
#include
#include
#include
using namespace std;

#include
#include
#include

static char program_name[]="bd";
#define THE_VERSION "0.1"

namespace info{
enum { WEST=0,NORTH=1,EAST=2,SOUTH=3,};
};
static char* deno[]={"Spade","Heart","Diamond","Cotton",};
static char card_symbol[]="23456789TJQKA";

// p - pointer to argument
// idx - index in argument
// default value
static int
get_number_arg(char* p,int def)
{
if (isdigit(*p))
{
def = atoi(p);
}
return def;
}

static void
print_help()
{
cout<<"Usage: "< cout<<"Bridge Dealer"< cout<<"Example: "< cout< cout<<" -p number of players, value ranges from 1 to 4"< cout<<" \""< cout<<" -v,--version print version information and exit"< cout<<" -h,--help display this help and exit"< cout< exit(0);
}

static void
print_version()
{
cout<#define BS_UNKNOWN_OPTION 0
"Too many arguments",
#define BS_TOO_MANY_ARGS 1
"Argument missing after",
#define BS_ARG_MISSING 2
"Garbage after option",
#define BS_GARBAGE 3
"Too many extra commands",
#define BS_EXTRA_CMD 4
"Invalid argument for",
#define BS_INVALID_ARG 5
};
//error message routines---------------end

int
main(int argc, char** argv)
{
int argv_idx = 1; /* active option letter is argv[0][argv_idx] */
int players=1;
int number_of_deals=1;
bool want_argument=false;

while(argc>0)
{
if(argv[0][0]=='-')
{
char c=argv[0][argv_idx++];
switch(c)
{
case 0:
//do nothing
argv_idx=-1;
break;
case '-': // "--" don't take any more options
if(strcmp(argv[0]+argv_idx,"version")==0){
print_version();
}
else if(strcmp(argv[0]+argv_idx,"help")==0){
print_help();
}
argv_idx=-1;
break;
case 'h':
print_help();
break;
case 'v':
print_version();
break;
case 'p': // 1,2,3,4 players, default 1
if (argv[0][argv_idx]){ // "-p{tag}"
players=get_number_arg(argv[0]+argv_idx,1);
argv_idx=-1;
}
else{ // "-p {tag}"
want_argument=true;
}
break;
case 'n': //number of deals, default 1
if (argv[0][argv_idx]){ // "-n{tag}"
number_of_deals=get_number_arg(argv[0]+argv_idx,1);
if(number_of_deals<=0) number_of_deals=1;
argv_idx=-1;
}
else{ // "-n {tag}"
want_argument=true;
}
break;
default:
break;
}


//handle options with argument
if(want_argument)
{
if (argv[0][argv_idx]){
cerr< exit(1);
}

--argc;
if (argc<1){
cerr< exit(1);
}
++argv;
argv_idx = -1;

switch(c)
{
case 'p':
players=get_number_arg(argv[0],1);
argv_idx=-1;
break;
case 'n':
number_of_deals=get_number_arg(argv[0],1);
if(number_of_deals<=0) number_of_deals=1;
argv_idx=-1;
break;
default:
; //impossible
}
}

}
else{
argv_idx=-1;//do nothing
}
// If there are no more letters after the current "-", go to next
// argument. argv_idx is set to -1 when the current argument is to be
// skipped.
if (argv_idx <= 0    argv[0][argv_idx] == 0)
{
--argc;
++argv;
argv_idx = 1;
}
}
//init
srand(time(0));

//original card
//value: spade, 0-12; heart, 13-25; diamond 26-38; cotton 39-51;
//array index: west, 0-12; north, 13-25; east 26-38; south 39-51;
const int dim=52;
int cards[dim];

for(int i=0;i {
cards[i]=i;
}
vector h(dim);
h.assign(cards,cards+dim);

//redeal
bool need_id=number_of_deals>1;
for(int k=0;k {
random_shuffle(h.begin(),h.end());
sort(h.begin()+info::WEST*13,h.begin()+info::WEST*13+13);
sort(h.begin()+info::NORTH*13,h.begin()+info::NORTH*13+13);
sort(h.begin()+info::EAST*13,h.begin()+info::EAST*13+13);
sort(h.begin()+info::SOUTH*13,h.begin()+info::SOUTH*13+13);

//dump
if(need_id){
cout<<"ID: "< }
switch(players)
{
case 1:
dump_one_hand(h.begin()+info::SOUTH*13);
break;
case 2:
dump_two_hands(h.begin()+info::EAST*13,h.begin()+info::WEST*13,26);
break;
case 3:
dump_one_hand(h.begin()+info::NORTH*13,26);
dump_one_hand(h.begin()+info::EAST*13);
dump_one_hand(h.begin()+info::SOUTH*13,26);
break;
case 4:
dump_one_hand(h.begin()+info::NORTH*13,26);
dump_two_hands(h.begin()+info::EAST*13,h.begin()+info::WEST*13,26);
dump_one_hand(h.begin()+info::SOUTH*13,26);
break;
default:
;//impossible
}
cout< }
return 0;
}编辑:xker.com

上一篇:写好C程序的10条秘籍
下一篇:没有了
关闭窗口】【技术交流】【收藏此页
相关文章
·C++中的const限定修饰符·C++类的继承与多重继承的访问控制·用 VC++和Winsock 实现与 HTTP 服务
·深入浅出VC++串口编程之DOS的串口编程·C++/CLI中实现singleton模式·C++箴言:为类型信息使用特征类
·Visual C++中回调函数使用的变身大法·Visual C++中轻松实现透明滑动控件·探索C++的秘密之详解extern
·VC++实现Windows系统回收站的文件存取·在VC++应用程序中实现颜色选择组合框·C++之父Bjarne谈C++中的STL模板
·用Visual C++语言在局域网实现IP多播·Visual C++ 2005中的命名返回值优化·C++箴言:分离出参数无关的代码
推荐文章 最新文章 热门文章
·最后防线 WinXP八种安全模式揭密
·原创:一个c++写的发牌程序
·借用WINS服务 让不同子网也能直接互通
·细处下手 尽力挖掘IIS6.0管理网站的新
·解决方案:Oracl数据库中大数据的备份
·WebServices调用存储过程
·快速排除广域网线路时通时断故障
·使用xml http为网站增加域名查询功能
·黑客技术揭秘:三招确定WWW服务类型
·联手杀毒软件 打造无毒迅雷下载文件
·Tomcat 配置技巧精华详解分析
·玩转系统 Window系统补丁知多少
·做好备份 硬盘数据大迁移
·中用也中看 全面打造个性化迅雷下载
·WIN2000下JSP服务器的安装
·李彦宏:5年后将很难看到Google
·实用小技巧:解决Word页码设置问题
·鼠标手绘:阳光清纯美少女
·最后防线 WinXP八种安全模式揭密
·原创:一个c++写的发牌程序
·借用WINS服务 让不同子网也能直接互通
·细处下手 尽力挖掘IIS6.0管理网站的新
·企业决策:如何简单三步选择SSL VPN
·如何实现IP核心网的QoS
·让程序开机自动运行的简易方法
·用流量监控控制限速的开关
·双绞线测试错误的解决方法
·解决方案:Oracl数据库中大数据的备份
·Oracle中关于逻辑备份与恢复
·局域网类故障简要分析
·个人简历表格
·免费代理IP(每日更新)
·QQ密码丢失后能做的事情:快速找回密码
·QQ收费头像免费使用的方法 
·Norton AntiVirus 2006 注册码(激活
·系统优化 专题
·WinRAR 3.51 注册码
·豪杰超级解霸V9.1正版注册码
·找回QQ密码的注意事项 
·史上最强QQ个人档案资料欣赏
·Ajax技术开发指南
·QQ空间皮肤代码
·最经典的黑客入门教材
·梦幻西游科举考试答案最新版
·求职简历封皮
评论

设为首页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
Copyright © 2003-2006 xker.com All rights reserved.小新技术网 合作广告QQ:12231446
本页浏览次数: