网站首页  软件下载  游戏下载  翻译软件  电子书下载  电影下载  电视剧下载  教程攻略

请输入您要查询的图书:

 

书名 短码之美(编程达人的心得技法)/图灵程序设计丛书
分类
作者 (日)Ozy
出版社 人民邮电出版社
下载
简介
编辑推荐

缩短代码的过程,是头脑风暴的过程。要想写出优秀的短码程序,除了要掌握数据结构、算法、运行环境方面的丰富知识以外,还要坚信无论什么样的源代码都能缩短,就算只能缩短1字节,也要为之不懈地努力。在这个过程中集中注意力,磨砺意志力,提升思考力。

程序人人会写,各有巧妙不同。本书以北京大学的在线评分系统为运行环境,给出了非常多的例子,足以让读者体会到如何写短码。作者除了详细介绍解题思路以外,还向读者传授不同程序语言的语法以及深入应用方面的知识,使读者在缩短源代码的过程中对程序设计语言、函数库和编程环境有更深入的了解。

如果你想提升程序设计水平,那么本书恰好适合你阅读。

内容推荐

本书主要介绍短码编程,首先介绍了短码编程的三要素:数据结构和算法、执行环境以及短码编程的精神。书中以北京大学的pku judge online 在线评分系统为编程环境,选取了该系统中比较典型的问题,如海狸啃木头、旋转拼图、葡萄酒买卖,利用数据结构和算法的知识加以分析,最后编程实现,并尝试使用各种编程语言,不断地将源代码缩短。同时还介绍并分析了一些钻安全漏洞的代码,旨在通过短码编程帮助程序员集中注意力,锻炼忍耐力,开拓视野。

本书适合所有对短码编程感兴趣的人。

目录

第1章 入门

 1.1 引言

1.1.1 什么是短码编程

1.1.2 短码编程的三要素

1.1.3 热情、聪明的短码编程者

1.1.4 短码编程者的传奇

 1.2 战场:在线评分系统

1.2.1 什么是在线评分系统

1.2.2 世界各地的在线评分系统

1.2.3 pku judge online

 1.3 动手试试:短码编程的基础

1.3.1 编程环境

1.3.2 使用的编程语言和编译器

1.3.3 注册poj账号

1.3.4 基本规则

1.3.5 微妙的规则

1.3.6 道德上的规则

 1.4 热身

1.4.1 关于运行环境

1.4.2 首先从简单的加法运算开始

1.4.3 不简单加法运算

1.4.4 计算平均值

1.4.5 推出重叠的牌

1.4.6 开始模仿编程

1.4.7 热身结束

第2章 必读!绝妙技巧

 2.1 精通规则

2.1.1 醉汉看守

2.1.2 阶段

2.1.3 连续数的和

 2.2 quick sort hack

2.2.1 快速排序

2.2.2 qsort函数

2.2.3 hack风暴

2.2.4 挑战变态排序一

2.2.5 挑战变态排序二

2.2.6 永远的hack

 2.3 熟练运用库函数

2.3.1 方便的库函数

2.3.2 好用的strtol函数

2.3.3 strtol与itoa天生一对

2.3.4 转换乐园

2.3.5 海狸啃木头

2.3.6 系绳

 2.4 精减1字节的靠山

2.4.1 好用的~运算符

2.4.2 好用的%运算符

2.4.3 分组建立长期政权

2.4.4 isbn码

2.4.5 非常活跃的数学问题

 2.5 按位运算的超级魔法

2.5.1 超级魔法的二叉树

2.5.2 超级魔法的密码

2.5.3 超级魔法的极致

 2.6 精通指针

2.6.1 短码编程中的指针

2.6.2 旋转拼图的智力游戏

2.6.3 超长加法

2.6.4 指针和数组的密切关系

 2.7 数学问题

2.7.1 不要依赖公式

2.7.2 越界(数列篇)

2.7.3 越界(排列组合篇)

2.7.4 与周期有关的问题

2.7.5 伪随机数的周期性

2.7.6 三个周期

2.7.7 斐波那契数列

 2.8 活用算法

2.8.1 高速、节省内存是编写短码的关键

2.8.2 三角形

 2.9 数字的新常识

2.9.1 关键在“三”

2.9.2 整理电话号码

 2.10 字节的热情

2.10.1 附上答案

2.10.2 汉诺塔

第3章 短码编程研究

 3.1 更高的编程技巧

3.1.1 开始

3.1.2 关于表示法

 3.2 精简循环

3.2.1 精通之后就能成为顶尖的短码编程者

3.2.2 简单的例子

3.2.3 常用结构

3.2.4 短码编程的基本类型

3.2.5 重要的短码语法

3.2.6 取数字游戏

3.2.7 葡萄酒买卖

3.2.8 难解:精简多层循环

 3.3 强大的扩展语法

3.3.1 对短码编程者有用的扩展语法

3.3.2 条件运算符

3.3.3 数字根

3.3.4 扩展左值

3.3.5 扩展关系运算符

 3.4 宏能不能缩短代码

3.4.1 基于短码编程的宏

3.4.2 while语句的可能性

3.4.3 数组的可能性

 3.5 神奇的main递归

3.5.1 main递归可以最大限度地缩短代码

3.5.2 从单纯循环到main递归

3.5.3 破解难题的main递归

3.5.4 基于递归算法的main递归

3.5.5 传说中的1145

3.5.6 小结

 3.6 quick sort hackⅱ

3.6.1 征服二进制等于征服短码编程

3.6.2 缩短汇编代码

3.6.3 进一步缩短

 3.7 作弊代码和安全性

 3.8 挑战难题

3.8.1 短码编程的灵魂

3.8.2 组成最强阵容

第4章 语言对决

 4.1 短码编程不限语言

4.1.1 各种程序设计语言

4.1.2 本章结构

 4.2 java与c

4.2.1 java是有缺陷的程序设计语言

4.2.2 使用java的地方

4.2.3 多精度时就交给java

4.2.4 c语言仍然强大

 4.3 pascal与c

4.3.1 遇到麻烦的pascal语言

4.3.2 用pascal写出比c语言更短的代码

4.3.3 复利计算

 4.4 c++与c

4.4.1 不经常使用的c++

4.4.2 基本技巧

4.4.3 检查顺序

4.4.4 g++扩展运算符与变态gcc源代码的对比

 4.5 更多的挑战

4.5.1 成为一名真正的短码编程者

4.5.2 世界各地的短码编程者的活动

4.5.3 挑战code golf

4.5.4 尝试用所有语言编写短码

第5章 磨练自己

 5.1 致亲爱的读者

5.1.1 向短码编程者学习

5.1.2 源代码的可读性

5.1.3 希望写出错误少的程序

5.1.4 更大程度地提高

5.1.5 有人情味、富有魅力

 5.2 珍贵的参考资料

5.2.1 珍贵的书籍

5.2.2 网站介绍

 5.3 精明强干的短码编程者

5.3.1 致谢

5.3.2 短码高手们(敬称略,按字母顺序)

 5.4 最后

附录

 a.1 问题一览

 a.2 ascii码表

 a.3 运算符的优先级与结合规则

随便看

 

霍普软件下载网电子书栏目提供海量电子书在线免费阅读及下载。

 

Copyright © 2002-2024 101bt.net All Rights Reserved
更新时间:2025/4/1 11:30:45