用列表+for循环生成乘法口诀表

 1 # 结合一下列表生成, 准备设计乘法表
 2 # numlist = [1,2,3,4,5]
 3 # [pow(i,3) for i in numlist]
 4 # ## [1, 8, 27, 64, 125]
 5 # [[pow(i,2), pow(i,3), pow(i,4) ] for i in numlist]
 6 # ## [[1, 1, 1], [4, 8, 16], [9, 27, 81], [16, 64, 256], [25, 125, 625]]
 7 '''
 8 乘法口诀表
 9 思路: 生成多个list ,拼成一个大list。 每一个小list作为乘法口诀表的一行,
10     再通过for循环将子list迭代出来,每一个子list占据一行。
11 '''
12 # 先生成一个大矩阵,由多个list组成的大list
13 numlist = [[0] * 10 for i in range(10)]
14 # numlist = [[0] * 9 ] * 9      #这么生成列表,结果就不对, 为什么?
15 # 可以通过下列语句列出矩阵。
16 # for n in numlist:
17 #     print(n)
18 
19 '''
20 定义行列: 
21 大矩阵list中,有9个小list, 每个list中有10个元素(因为最后不需要索引0这个元素)。
22 每一个小list就是乘法表的一行, list中的元素就是对应行的‘列’
23 '''
24 # 开始循环,每行循环一次 , 从第一行循环到第九行。
25 for l in range(1, 10):
26     # 开始列循环, 每行中循环为行中每列赋值。 从第一列循环到第九列。
27     for r in range(1, 10):
28         # 算法是 numlist[行][列]索引的元素值 == 所在行x所在列, 但是这块需要注意一下:
29         # 我们常见的口诀表,实际上显示的格式是 列x行=结果, 如: 1x2=2 ,2x2=4 ,
30         # 因此,使用这种方式进行字符串格式化,但是实际循环式,使用的循环方式是在行循环中依次对列进行循环。
31         numlist[l][r] = "{}x{}={}".format(r, l, r*l)
32 
33 print('\n', ' ' * 20, '九九乘法表')
34 # 完成为大矩阵list赋值后, 开始通过for循环将大矩阵list中的每一个小list迭代出来
35 # 开始行循环,每行循环一次,从第一行循环到第九行。
36 for l in range(1, 10):
37     # 开始列循环。
38     # 旗形口诀表,每行的乘数等于被乘数后,该行即结束。
39     # 反应到算法上,由于大矩阵list中第一个小list(第1行)索引为0,因此每行中列循环次数==该行所处list索引数+1, 这样用来生成旗形口诀表。
40     # 如果使用 for r in range(1,10): 这样输出的是矩阵。
41     for r in range(1, l+1):
42         print(numlist[l][r], end=' ')
43     # 每列循环完,插入一个换行动作
44     print()
45 # for n in numlist:
46 #     print(n)

执行结果:

                      九九乘法表
1x1=1
1x2=2 2x2=4
1x3=3 2x3=6 3x3=9
1x4=4 2x4=8 3x4=12 4x4=16
1x5=5 2x5=10 3x5=15 4x5=20 5x5=25
1x6=6 2x6=12 3x6=18 4x6=24 5x6=30 6x6=36
1x7=7 2x7=14 3x7=21 4x7=28 5x7=35 6x7=42 7x7=49
1x8=8 2x8=16 3x8=24 4x8=32 5x8=40 6x8=48 7x8=56 8x8=64
1x9=9 2x9=18 3x9=27 4x9=36 5x9=45 6x9=54 7x9=63 8x9=72 9x9=81

转载于:https://www.cnblogs.com/konggg/p/9188187.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/251552.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

event.target【转载】

[转载] 1.this和event.target的区别: js中事件是会冒泡的,所以this是可以变化的,但event.target不会变化,它永远是直接接受事件的目标DOM元素; 2.this和event.target都是dom对象,如果要使用jquey中的方法可…

node --- http数据上传

// 通过报头的Transfer-Encoding或Content-Length即可判断请求中是否带有内容 var hasBody function(req) {return transfer-encoding in req.headers || content-length in req.headers; };// 在HTTP_Parser解析报头结束后,报文内容部分会通过data事件触发 function (req, re…

MVC是架构模式,而不是设计模式

最早学编程的时候看过一些书,印象深刻的一本书《设计模式解析》,那本书给我后来的工作提供了很大的帮助。 他叫我站在问题模型的立场上指定解决方法,也教会了我软件设计中每个问题都可以细化到到不可再分割的原子性。 在那书以后看到过一些设…

msp430入门编程42

msp430中C语言的软件工程--事件触发程序结构 转载于:https://www.cnblogs.com/guochaoxxl/p/7812773.html

使用DataTable作为存储过程的参数

最近工作中写了几个存储过程,需要向存 储过程中传递字符串,因为SQL Server 2000中没有内置类似于 split 的函数,只好自己处理,将前台数据集中的一列用逗号拆分存到一个List中,再转化为字符串传给存储过程,很…

CodeForces - 976F Minimal k-covering

Description 给你一张左边 \(n_1\) 个点,右边 \(n_2\) 个点, \(m\) 条边的二分图。对于每一个 \(0\le k\le minDeg\) ,求选取哪些边可以使每个点的度数都不小于 \(k\) 。 \(1\le n_1,n_2\le 2000\) , \(m\le 2000\) Solution 大力…

进制转换详细解说

进制的由来:任何数据在计算机中都是以二进制的形式存在的。二进制早起由电信号开关演变而来。 一个整数在内存中一样也是二进制的,但是使用一大串的1或者0组成的数值进行使用很麻烦 所以就想把一大串缩短点,讲二进制中的三位用一位表示。 这三…

删除Windows 7自动创建的隐藏分区

如果你安装了Windows 7测试版,在安装完成后发现Windows 7自动划出一个隐藏的分区,大小为200MB的。又不懂该怎样删除? 其实这个隐藏分区的删除比较麻烦的,如果贸然使用DM等分区工具来删除,会损坏硬盘的分区表。即使是使…

jQuery --- 简单操作合集

// 获取所有<p>元素 $("p");// 获取一个ID为myDiv的<div>元素 $("div#myDiv");// 获取所有type属性等于"text"的<input>元素 $("input[typetext]");// 获取所有p元素并隐藏它们 $("p").hide();// 获取ID为…

6.2 常见多媒体标准及压缩技术

MPEG-1是视频的压缩标准.这个标准是在1993年8月份发布的.标准就规定了视频文件以每秒钟1.5MB的速率来传输数字媒体它的运动图像以及伴音的编码.这个标准它包括了五个部分. MPEG-2它是1994年推出来的一个压缩标准&#xff0c;也是用于视频的。MPEG-2、MPEG-4、MPEG-7、MPEG-21它…

Single Number II

2018-06-17 14:04:27 问题描述&#xff1a; 问题求解&#xff1a; 方法一、如果对空间复杂度没有要求&#xff0c;那么直接使用HashMap对每个数字出现次数进行计数&#xff0c;最后对HashMap遍历一遍即可&#xff0c;总的时间复杂度为O(n)&#xff0c;空间开销较大。 方法二、对…

JavaScript --- 自定义优先级队列

根据HTTP1.1的规范,一个客户端在同一时刻与同一域名不能有两个以上的连接。为了完全符合HTTP1.1,一个典型的解决方案就是使用优先级队列.下面是自定义的优先级队列 /** * 用原型模式定义PriorityQueue的方法, * 如果没有定义_compare()方法,那么第一个方法就是默认的_compare(…

可添加至收藏夹并在浏览器地址栏运行的JS代码

编辑当前网页 代码如下&#xff1a; javascript:document.body.contentEditabletrue; document.designModeon; void 0 无敌图片风火轮 在地址栏运行下面的代码可提取所有图片元素在页面上滚动显示&#xff0c;属于网页显示特效。 代码如下&#xff1a; javascript:R0; x1.1; y1…

SOA相关资料

http://www.cnblogs.com/mushroom/p/4369032.html转载于:https://www.cnblogs.com/tianciliangen/p/7825959.html

打造自己Django博客日记

本教程使用的开发环境 本教程写作时开发环境的系统平台为 Windows 10 &#xff08;64 位&#xff09;&#xff0c;Python 版本为 3.5.2 &#xff08;64 位&#xff09;&#xff0c;Django 版本为 1.10.6。 建议尽可能地与教程的开发环境保持一致&#xff08;尤其是 Python 与 D…

vue --- 使用字符串'api'跨域请求资源

vue环境下,修改config/index.js文件 module.exports {data: {proxyTable: {/api: {target: http://siwei.me, // 将api转发到siwei.me上changeOrigin: true,pathRewrite: {^/api: // 去掉url中的api}}}, }原请求: http://localhost:8080/api/interface/blogs/all 新请…

重庆两江新区将建国内最大“云计算”数据基地

全市经济工作会指出&#xff0c;要尽快启动、全力争取打造国内最大的数据处理基地&#xff0c;最终要做成上百万台服务器、上千亿美元规模的“云计算”基地&#xff0c;成为全球数据开发和处理中心。昨日&#xff0c;市经信委主任沐华平接受本报专访时表示&#xff0c;重庆正在…

如何在前端生成二维码

第一步&#xff1a; 引入&#xff1a;<script src"qrcode.js"></script> 第二步&#xff1a; <div id"qrcode"></div> 第三步&#xff1a; // 1.简单使用方式 &#xff1a;new QRCode(document.getElementById(qrcode), http://ww…

vue --- Vue中的路由跳转问题

import Vue from vue import Router from vue-router // 前2个导入时vue框架自带的 import SayHi from /components/SayHi // 这个导入是自己写的位于components下的sayHiVue.use(Router) // 用到了vue的Router模块 export default new Router({routes: [{path: /say_hi,…

水瓶与天蝎的八年爱恋(图

新浪网友&#xff1a;kinkihi 水瓶与天蝎的八年爱恋我水瓶&#xff0c;他蝎子。我们相恋8年&#xff0c;确切的说中间有5年在一起的时间不超过6个月&#xff0c;两人一直处于异地状态&#xff0c;说出来可能没几个人能信&#xff0c;我们是这样走过来的。我一直是严格要求自己&…