珠玑编程读书笔记——<二>

感觉还是得要有本纸质的书本,看了一下评价,都说翻译太烂了。

果断要了本E文版的,读起来有点吃力。六级果然也就是浮云。

感觉自己实力真是有限,所以忍不住想说明一下:这纯属个人读书笔记,偶尔看到我的笔记的朋友,如果有意见欢迎提出、指正,不过请注意用语。


进度有点慢,所以本章的三个问题还是一个一个来吧。


问题:给定一个包含了40亿个32位整数的顺序文件且整数的次序是随机的。请找出一个文件中没有出现的32位整数(至少能找出一个,Why?)。在主存足够的情况下你会怎么做?如果你可以使用若干外部临时文件但是主存只有几百字节,你又会怎么做?

   第一反应,我想起了小学时候碰到的一道智力题:一堆(100个)从外观上无法区分的硬币(玻璃弹珠.....),其中有一个假币,特征是重量比真币要轻,可用道具——天平,至少称量几次能找出假币。相信各位看官都已有了答案。其实就是利用二分法原理。

  二分法效率很高,探测次数不会超过log2n,在处理海量数据时表现很好。所以使用本题。但是很多二分查找的程序很难写。对于我,用程序实现此题的解,我现在还做不到,因为对于处理文件经验不足,老是感觉有点障碍。不过可以先分析、理解一下算法。

 首先考虑主存足够的情况,回顾前一章,正是,可以使用位图。32位的整数有多少个呢?2的32次,也就是4,294,967,296个(文件中是40亿个,所以只要你认真去找一定能找到文件中遗漏的数),那么就需要536,870,912 个8位(书中的写法)分配给一个位图来表示所有的数。对于作者的这表示让我好好的想了想,为什么不是268,435,456个16位,不是134,217,728个32位。而后面突然反应过来,这样表示可以一样看出这位图将占用536M的内存。536M确实可以说很耗内存了。在我的经验中,Myeclipse会占到100~200M,PS会占到200M+,Opera在开很多选项卡的时候会到400M+,Pl/Sql在数据量到千万以上时会占到500M+,这时我这机器开始卡了。 

 现在考虑问题中所说的只有几百字节,书中给的算法:在包含至少一个遗漏元素的范围中

 read number line from file

        IF number < midpoint
              write number into lower file
        ELSE
              write number into upper file

这样一来元素较少的那一半一定是包含了遗漏的元素(数字)。如此递归下去,终能找出那个“元凶”。

这些天为了维护一个程序,折腾得有点疲了,今天就到这吧。

当然,还得记住,还欠一个代码实现。

优化这段代码<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>图书购物车</title> <style> </style> <script src="js/vue.js"></script> </head> <body> <div id="demo"> <table border="1"> <tr> <td></td> <td>书籍名称</td> <td>出版日期</td> <td>价格</td> <td>购买数量</td> <td>操作</td> </tr> <tr> <td></td> <td>{{books1.name}}</td> <td>{{books1.date}}</td> <td>¥{{books1.price}}</td> <td><button @click="down(books1)">-</button>{{books4.count}}<button @click="up(books1)">+</button></td> <td><button @click="del">移除</button></td> </tr> <tr> <td></td> <td>{{books2.name}}</td> <td>{{books2.date}}</td> <td>¥{{books2.price}}</td> <td> <button @click="down(books2)">-</button>{{books4.count}}<button @click="up(books2)">+</button> </td> <td><button @click="del">移除</button></td> </tr> <tr> <td></td> <td>{{books3.name}}</td> <td>{{books3.date}}</td> <td>¥{{books3.price}}</td> <td> <button @click="down(books3)">-</button>{{books4.count}}<button @click="up(books3)">+</button> </td> <td><button @click="del">移除</button></td> </tr> <tr> <td></td> <td>{{books4.name}}</td> <td>{{books4.date}}</td> <td>¥{{books4.price}}</td> <td> <button @click="down(books4)">-</button>{{books4.count}}<button @click="up(books4)">+</button> </td> <td><button @click="del">移除</button></td> </tr> </table> <div>总价: ¥{{sum}}</div> </div> <!-- js部分 --> <script> const vm = new Vue({ el: "#demo", data: { books1: { name: '《算法导论》', date: '2006-9', price: 85.00, count: 1 }, books2: { name: '《UNIX编程艺术》', date: '2006-2', price: 59.00, count: 1 }, books3: { name: '《编程珠玑》', date: '2008-10', price: 39.00, count: 1 }, books4: { name: '《代码大全》', date: '2006-3', price: 128.00, count: 1 } }, computed: { sum () { return this.books1.price * this.books1.count + this.books2.price * this.books2.count + this.books3.price * this.books3.count + this.books4.price * this.books4.count } }, methods: { down (books1) { this.books1.count = books1.count - 1; } } }) </script> </body> </html>
最新发布
04-21
优化建议: 1. 使用数组来存储书籍信息,可以避免重复的代码和变量 2. 使用计算属性来计算总价,避免重复计算 3. 将操作封装成方法,并使用可复用的组件来渲染每一行 优化后的代码如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>图书购物车</title> <style> </style> <script src="js/vue.js"></script> </head> <body> <div id="demo"> <table border="1"> <tr> <td></td> <<td>书籍名称</td> <td>出版日期</td> <td>价格</td> <td>购买数量</td> <td>操作</td> </tr> <book-row v-for="(book, index) in books" :book="book" :index="index" :key="index" @change-count="changeCount" @remove-book="removeBook" /> </table> <div>总价: ¥{{totalPrice}}</div> </div> <!-- js部分 --> <script> Vue.component('book-row', { props: ['book', 'index'], methods: { down() { if (this.book.count > 1) { this.book.count--; this.$emit('change-count'); } }, up() { this.book.count++; this.$emit('change-count'); }, remove() { this.$emit('remove-book', this.index); } }, template: ` <tr> <td></td> <td>{{book.name}}</td> <td>{{book.date}}</td> <td>¥{{book.price}}</td> <td> <button @click="down">-</button> {{book.count}} <button @click="up">+</button> </td> <td> <button @click="remove">移除</button> </td> </tr> ` }); const vm = new Vue({ el: "#demo", data() { return { books: [ { name: '书籍1', date: '2022-01-01', price: 30, count: 1 }, { name: '书籍2', date: '2022-01-01', price: 40, count: 1 }, { name: '书籍3', date: '2022-01-01', price: 50, count: 1 }, { name: '书籍4', date: '2022-01-01', price: 60, count: 1 } ] }; }, methods: { changeCount() { // 重新计算总价 }, removeBook(index) { this.books.splice(index, 1); // 重新计算总价 }, }, computed: { totalPrice() { return this.books.reduce((acc, cur) => acc + cur.price * cur.count, 0); } } }); </script> </body> </html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值