20190105-打印字母C,H,N,口等图像和杨辉三角
1. 打印字母C
******
*
*
*
*
******
def print_c(n):
print('*' * n)
for i in range(n):
print('* ')
print('*' * n)
print_c(20)
2.打印字母N
* *
* * *
* * *
* * *
* *
算法:N在左下角空心三角形的基础上减去最后一行的*,并在每行后面打印一个*,设定N的宽=N的高,打印心三角形详见20190103这篇文章
def print_N(n):
for i in range(n+1):
#打印的行数
for j in range(n+1):
#每行打印的*个数(N的宽度),仅打印首尾的*,空间以空格分隔
if j ==0 or j==i:
print('*',end = ' ')
#打印第一个和斜杠中的*,j==i的时候打印斜杠中的*起始点
elif j==n:
print('*',end ='')
#打印N中第二个直线位置的*,此处end=''与end =' '没有区别,因为j=n是最后一遍循环,之后就是换行了
else:
print(' ',end = ' ')
#其他位置用空格填充
print()
Print_N(10)
3.打印口
* * * * * *
* *
* *
* * * * * *
口除第一行和最后一行全部打印外,其他行仅打印首尾,定义口的高和宽
def quadrangle(hight,width):
for i in range(hight+1):
for j in range(width+1):
if i ==0 or i ==hight:
print('*',end =' ')
#空心四边形第一行全部打印
elif j==0 or j ==width:
print('*',end =' ')
#空心四边形中间行数打印首尾
else:
print(' ',end =' ')
print()
quadrangle(10,10)
4.打印H
* *
* *
* * * * *
* *
* *
算法:H,分为高和宽,设定宽为高的一半因此我们写H的时候只需要指定H的高就好
def print_H(height):
if isinstance(height,int) and height>=5:
for i in range(height+1):
#打印H的高
for j in range(int(height/2)+1):
if i ==int(height/2):
print('*',end = ' ')
elif j ==0 or j==int(height/2):
print('*',end =' ')
else:
print(' ',end =' ')
print()
else:
print('请设定H的高度大于5')
print_H(10)
H的高度必须大于5的原因是为了大于H中间那条横,因为j的范围为height/2+1,当height=4一下的时候,j打印的*小于2,因此无法打印除H中间的那一横
5.打印杨辉三角
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
将每一行看作一个list,先写除一个 方法输出下一行的list值
def pascal_list_generate(list):
#print(len(list))
pascal =[]
if len(list)>=2:#因为需要取第i-1个值,因此len(list)必须大于等于2,如果len(list)=1,则i-1<0,程序报错
for i in range(len(list)+1):
if i ==0:
pascal.append(1)
#杨辉三角的第一和最后一位数为1
elif i>=1 and i <len(list):
pascal.append(list[i]+list[i-1])
#除第一个和最后一个数外杨辉三角第n行的第m个数为第n-1行第m和m-1的数之和
elif i==len(list):
#杨辉三角的第一和最后一位数为1
pascal.append(1)
else:
pascal.append(1)
pascal.append(1)
#兼容杨辉三角第二行的情况
return pascal
写一个打印杨辉三角每行的函数,并且可以自定义杨辉三角的行数
def pascal_trigal(n):
s =[1]
if n ==1:
print(s)
else:
print(s)
for i in range(n-1):
print(pascal_list_generate(s))
s = pascal_list_generate(s)
pascal_trigal(10)
在杨辉三角的方法里面循环迭代调用每一行的生成方法。
20190105-打印字母C,H,N,口等图像和杨辉三角的更多相关文章
- C语言打印杨辉三角(2种方法)
杨辉三角是我们从初中就知道的,现在,让我们用C语言将它在计算机上显示出来. 在初中,我们就知道,杨辉三角的两个腰边的数都是1,其它位置的数都是上顶上两个数之和.这就是我们用C语言写杨辉三角的关键之一. ...
- 使用Java打印杨辉三角
package 杨辉三角; import java.util.Scanner; public class 三角 { private static Scanner scn; public static ...
- java代码打印打印杨辉三角
郑州大学 徐峰 public class Print { void print(){ int[][] a=new int[6][6]; for(int i=0;i<a.length;i++){ ...
- 打印杨辉三角--for循环
要求打印7行直角杨辉三角 杨辉三角特点: 第1行和第2行数字都为1: 从第三行开始,除去开头和结尾数字为1,中间数字为上一行斜对角两个数字的和. 如下图: 打印结果: 代码如下: package 杨辉 ...
- [Java练习题] -- 1. 使用java打印杨辉三角
package cn.fzm.demo1.array; import java.util.Scanner; /* * 需求:打印杨辉三角形(行数可以键盘录入) 1 1 1 1 2 1 1 3 3 1 ...
- 杨辉三角的打印(Java)
// //输入指定的行数,打印杨辉三角 // //每个数等于它上方两数之和. //每行数字左右对称,由1开始逐渐变大. //第n行的数字有n项. // // // //可从打印菱形的思想出发:???? ...
- 利用python打印杨辉三角
用python打印杨辉三角 介绍 杨辉三角,是初高中时候的一个数列,其核心思想就是说生成一个数列,该数列中的每一个元素,都是之前一个数列中,同样位置的元素和前一个元素的和. 正好在python中,也就 ...
- C#打印杨辉三角
重主要的方法在于: 1.初始化二维数组 2.边界赋值 3.中心值赋值 4.输出 <pre name="code" class="csharp"> c ...
- C语言复习---杨辉三角打印
#define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <stdlib.h> #include <math ...
随机推荐
- 通过 Powershell 来替换 ARM 模式下虚拟机的网络接口
需求描述 客户在部署完 ARM 模式的虚拟机以后,由于误操作在虚拟机内部禁用了网卡导致远程访问虚拟机受到限制,以下是通过 Powershell 命令来替换原有虚拟网络接口实现虚拟网卡重置功能. Not ...
- ubuntu 18 下配置 WebStorm 编译 sass
ubuntu 18 下配置 WebStorm 编译 scss 标签(空格分隔): IDE 安装Ruby: sudo apt-get install ruby ruby -v ruby 2.5.1p57 ...
- groupadd
功能说明:用于创建新的用户组. 参数选项:-g gid 指定用户组的gid,除非接-o参数,否则ID值唯一且不为负,如果不指定-g参数,则gid从500开始.-f 新增一个账户,强制覆盖一个已存在的组 ...
- “标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法
“标准查询运算符”是组成语言集成查询 (LINQ) 模式的方法.大多数这些方法都在序列上运行,其中的序列是一个对象,其类型实现了IEnumerable<T> 接口或 IQueryable& ...
- 高通Vuforia
这里使用高通的Vuroria来做一个AR歌姬. 工具: Vuforia,MMD4Mecanim 模型: 初音未来pmd模型文件,极乐净土vmd动作文件. 逻辑: 当发现识别卡时:开启音乐,模型速度为1 ...
- TSP 模拟退火
TSP——模拟退火解法 都知道TSP是经典的NP问题,从一个点开始遍历所有点,不重复,求最短路径. 可以用枚举终点,跑流量为2的最小费用,图论来做,时间复杂度为 费用流已经用到堆优化了.显然点,边 ...
- SPOJ MUSKET - Musketeers
黑书P117页. 要是不看解析,确实不要算和定义状态. 把环看成链,是指把这个1234512345,写两边,然后怎么表示一个人是否胜利了呢?其实就是其他人全部死光(好像等于没说): 考虑最后一次杀人, ...
- POJ 1830 开关问题 【01矩阵 高斯消元】
任意门:http://poj.org/problem?id=1830 开关问题 Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 1 ...
- 2018中国大学生程序设计竞赛 - 网络选拔赛 1010 YJJ's Salesman 【离散化+树状数组维护区间最大值】
题目传送门:http://acm.hdu.edu.cn/showproblem.php?pid=6447 YJJ's Salesman Time Limit: 4000/2000 MS (Java/O ...
- [19/03/15-星期五] 常用类_String类&StringBuilder和StringBuffer类
一.基本概念 String 类对象代表不可变的Unicode字符序列,因此我们可以将String对象称为“不可变对象”. 那什么叫做“不可变对象”呢? 指的是对象内部的成员变量的值无法再改变.Str ...