用数据结构删除一串数值中重复的值如何编写(要C语言环境下执行,要完整的程序)

如题所述

第1个回答  2013-12-07
1. 使用整数和长整数  提高代码运行速度最简单的方法莫过于使用正确的数据类型了。也许你不相信,但是正确地选择数据类型可以大幅度提升代码的性能。在大多数情况下,程序员可以将短整数型、小数型和双精度小数型的变量替换为整数(Integer)或长整数(Long)类型的变量,因为易语言处理整数和长整数的能力远远高于处理其它几种数据类型。  在大多数情况下,程序员选择使用小数型或双精度小数型的原因是因为它们能够保存小数。但是小数也可以保存在整数类型的变量中。例如程序中约定有三位小数,那么只需要将保存在整数型变量中的数值除以1000就可以得到结果。根据我的经验,使用整数和长整数替代短整数型、小数型和双精度小数型后,代码的运行速度可以提高将近10倍。 但是我们也不要老是强调使用使用整数和长整数,因为在程序中数据类型的定义还牵涉一个关键的问题,就是数据的安全,频繁而无规范地定义 数据类型会使算法出现漏洞,是数据的安全和临界判断有问题.对财务和工程计算而言,小数点的精度是很敏感的数据,只能用双精度数据来规范.另外, 换成整型也会导致程序可读性急剧下降. 2. 避免使用通用型数据   通用型的变量需要16个字节的空间来保存数据,而一个整数(Integer)只需要2个字节。通常使用通用型变量的目的是为了减少设计的工作量和代码量,也有的程序员图个省事而使用它。但是如果一个软件经过了严格设计和按照规范编码的话,完全可以避免使用变体类型。 3. 尽量避免使用属性  在平时的代码中,最常见的比较低效的代码就是在可以使用变量的情况下,反复使用属性(Property),尤其是在循环中。要知道存取变量的速度是存取属性的速度的20倍左右。下面这段代码是很多程序员在程序中会使用到的: 容器名: 数值 类型:整数型容器名: 容器 类型:整数型 计次循环首(7,容器) 文本1.内容 = 文本1.内容 + #换行符 + 到文本((数值×容器))计次循环尾()  下面这段代码的执行速度是上面代码的20倍。 容器名: 数值 类型:整数型容器名: 容器 类型:整数型容器名: 文本 类型:文本型 文本 = 文本1.内容 计次循环首(7,容器) 文本 = 文本 + #换行符 + 到文本((数值×容器))计次循环尾()文本1.内容 = 文本 另外要注意,这个涉及一个编程思路, 用属性当变量的作法大多数情况可以简化算法。所以有时候也不能一味强调用变量代替属性。 6. 避免调用很短的子程序  调用只有几行代码的子程序也是不经济的--调用子程序所花费的时间或许比执行子程序中的代码需要更长的时间。在这种情况下,你可以把子程序中的代码拷贝到原来调用子程序的地方。 但是有时候小的子程序可能会被调用很多次而不是只有两三次,这时就应该调用它。 7. 减少对子对象的引用  在易语言中,通过使用.来实现对象的引用。例如: 窗口1.编辑框1.内容  在上面的例子中,程序引用了两个对象:窗口1和编辑框1。利用这种方法引用效率很低。但遗憾的是,没有办法可以避免它。我的“多媒体模块”就有这个缺点。 8. 检查文本型数据是否为空  大多数易语言用户在检查文本型数据是否为空时会使用下面的方法: 如果 (文本1.内容 = "" ) 注释: 执行操作 结束如果  很不幸,进行字符串比较需要的处理量甚至比读取属性还要大。因此我建议大家使用下面的方法: 如果 (到数值(文本1.内容) = 0 ) 注释: 执行操作 结束如果 另一个不同的意见是:问题在于当文本字串为 "ABC"之类的非数值型时, 到数值("ABC")=0并不表示为空。文本比较的效率并不低,在底层算法中,一般会直接比较长度才会继续比较内容。 9. 使用数组,而不是多个变量  当你有多个保存类似数据的变量时,可以考虑将他们用一个数组代替。在易语言中,数组是最高效的数据结构之一。 10. 尽量使用动态数组,而不是静态数组  使用动态数组对代码的执行速度不会产生太大的影响,但是在某些情况下可以节约大量的资源。 11. 销毁对象  无论编写的是什么软件,程序员都需要考虑在用户决定终止软件运行后释放软件占用的内存空间。但遗憾的是很多用户对这一点好像并不是很在意。正确的做法是在退出程序前需要销毁程序

如果帮助到您,请记得采纳为满意答案哈,谢谢!祝您生活愉快! vae.la
相似回答