在控制台用星号打印一个高M的等腰三角形与菱形
2015-06-06 00:00
736 查看
摘要: 等腰三角形与菱形的规律很相似
分析:
分三种情况:
①第一行:只打空格,然后打一个*
②最后一行:全打*,不打空格
③中间:打左边空格,然后打一个*,再打空格,再打一个*
第一行:空格:总行数-1
最后一行:行号 * 2 + 1 个星号
中间:总行数-1-行号 个空格、1个星号, 行号*2-1 个空格,1个星号
菱形可以理解为:
分为上下的空心三角形,规律也相似
等腰三角形
效果图:分析:
分三种情况:
①第一行:只打空格,然后打一个*
②最后一行:全打*,不打空格
③中间:打左边空格,然后打一个*,再打空格,再打一个*
第一行:空格:总行数-1
最后一行:行号 * 2 + 1 个星号
中间:总行数-1-行号 个空格、1个星号, 行号*2-1 个空格,1个星号
public class BlankTri { public static void main(String[] args) { int M = 8; // i就代表了要打印i行 for (int i = 0 ; i < M ; i++ ) { if (i == 0) // 正在打印第一行。 { // 总行数-1 个空格、1个星号 for(int j = 0 ; j < M - 1; j++) { System.out.print(" "); } System.out.print("*"); } else if (i == M - 1) // 正在打印最后一行。 { // 最后一行要打印 行号 * 2 + 1 个星号。 for(int j = 0 ; j < i * 2 + 1 ; j++) &nb 3ff0 sp; { System.out.print("*"); } } else{ // 中间的行数 // 总行数-1-行号 个空格、1个星号, 行号*2-1 个空格,1个星号 for(int j = 0 ; j < M - 1 - i ; j++) { System.out.print(" "); } System.out.print("*"); for(int j = 0 ; j < i * 2 - 1 ; j++) { System.out.print(" "); } System.out.print("*"); } // 每打印一行之后,应该换个行 System.out.println(); } } }
菱形
效果:菱形可以理解为:
分为上下的空心三角形,规律也相似
public class 空心菱形 { public static void main(String[] args) { int M = 9; // 假如上面三角形高度为7,那么菱形高度为13 for (int i = 0; i < M * 2 - 1; i++) { // 第一行、最后一行,都是打印 M - 1个空格 ,1个星号。 if (i == 0 || i == M * 2 - 2) // 第一行 或 最后一行 { for (int j = 0; j < M - 1; j++) { System.out.print(" "); } System.out.print("*"); } // 如果是上面一半, else if (i < M) { // 总行数-1-行号 个空格、1个星号, 行号*2-1 个空格,1个星号 for (int j = 0; j < M - 1 - i; j++) { System.out.print(" "); } System.out.print("*"); for (int j = 0; j < i * 2 - 1; j++) { System.out.print(" "); } System.out.print("*"); } else if (i >= M) { // 行号-总行数+1 个空格、1个星号, 4 * M - 5 - 2*i 个空格,1个星号 for (int j = 0; j < i - M + 1; j++) { System.out.print(" "); } System.out.print("*"); for (int j = 0; j < 4 * M - 5 - 2 * i; j++) { System.out.print(" "); } System.out.print("*"); } System.out.println(); } } }
相关文章推荐
- java对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- Android IPC进程间通讯机制
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- PropertyChangeListener简单理解
- 插入排序
- 冒泡排序
- 堆排序
- 快速排序
- 二叉查找树
- [原创]java局域网聊天系统