JavaSE之绘制菱形
在JavaSE的算法练习中,绘制菱形是一个比较常见的案例。菱形效果如下图所示:

我们在解决算法问题时,通常情况下,先不要急于马上编码,而是要先观察,找出解决问题的关键所在。
在上图中,我们可以看到,菱形的行数与列数均可沿水平或垂直中轴线予以对折,故菱形的行数与列数均应为奇数;
菱形左上角的空格数量,从顶部至水平中轴线,依次递减,具体说来每行递减一个空格,直至水平中轴线处无空格;
菱形顶部与底部各有一个星号,顶部与底部之间(不含顶部与底部)的部分每行有两个星号,每行其余部分除了星号外均是空格,而且在菱形的上半部分,每行的星号为行起始处(列角标为0),以及列角标为该行次序的2倍数(起始为0,如:起始0行中的星号坐标为0行0列、0行2*0列,即一个星号;1行中的星号坐标为1行0列、1行2*1列,即两个星号;2行中的星号坐标为2行0列、2行2*2列,两个星号;以此类推);
菱形的上半部分沿水平中轴线对折,即可得到菱形的下半部分,从而完成菱形的绘制。
我们在做完上述的算法分析后,接下来通过编码实现菱形的绘制。请详见下述代码:
import java.util.Scanner;
/**
* 绘制菱形
* @author 李章勇
*
*/
public class Demo { public static void main(String[] args) {
Scanner sc=new Scanner(System.in);//创建一个键盘输入对象
System.out.println("请输入一个整数:");//提示输入
int size=sc.nextInt();//输入一个整数,并赋值给size变量
sc.close();//关闭输入流
if(size%2==0){//判断若不为奇数,则将其加1变为奇数
size+=1;
}
//绘制菱形的上半部分
for(int i=0;i<=size/2;i++){
for(int j=size/2;j>i;j--){//菱形的上半部分的左上角处空格绘制
System.out.print(" ");
} for(int j=0;j<=2*i;j++){//菱形中星号与空格的绘制
if(j==0 || j==2*i){
System.out.print("*");
}else{
System.out.print(" ");
}
}
System.out.println();//绘制好一行就换行 }
//开始绘制菱形的下半部分
int k=0;
for(int i=size/2+1;i<size;i++){
k+=2;//由于是沿水平中轴线对折,故菱形的下半部分中,紧邻菱形水平中轴线的行,相当于其上两行的菱形行的对折,以此类推
for(int j=0;j<i-size/2;j++){
System.out.print(" ");
}
for(int j=0;j<=2*(i-k);j++){
if(j==0 || j==2*(i-k)){
System.out.print("*");
}else{
System.out.print(" ");
}
}
System.out.println();
}
}
}
运行上述代码,显示效果如下:

此外,还可以通过下述方法绘制菱形:
package com.itszt.test5;
/**
* 绘制菱形,
*/
public class Test2 {
public static void main(String[] args) {
//绘制菱形,10,行列为奇数
int n=10;
if(n%2==0)
{
n+=1;
}
//上半部分,0--->n/2
for(int i=0;i<=n/2;i++){
for(int j=n/2;j>i;j--){
System.out.print(" ");
}
for(int j=0;j<=2*i;j++){
if(j==0 || j==2*i){
System.out.print("*");
}else{
System.out.print(" ");
}
}
System.out.println();
}
//下半部分
for(int i=n/2-1;i>=0;i--){
for(int j=i;j<n/2;j++){
System.out.print(" ");
}
for(int j=0;j<=2*i;j++){
if(j==0 || j==2*i){
System.out.print("*");
}else{
System.out.print(" ");
}
}
System.out.println();
} }
}
JavaSE之绘制菱形的更多相关文章
- OpenGL的几何变换[转]
OpenGL的几何变换 1.实验目的: 理解掌握一个OpenGL程序平移.旋转.缩放变换的方法. 2.实验内容: (1)阅读实验原理,运行示范实验代码,掌握OpenGL程序平移.旋转.缩放变换的方法: ...
- (生活)Photoshop入门(不定时更新)
我可能是想找个工作以外的事情做一下. 目标:我要自学网PhotoShop商业修图. 笔记: .图层 .1总结: 1.1.1图层就好像画画的一张纸,但是每一层又互不影响. 1.1.2图层蒙版(覆盖一层玻 ...
- 实验3 OpenGL几何变换
转自:http://www.cnblogs.com/opengl/archive/2012/10/30/2747130.html 1.实验目的: 理解掌握一个OpenGL程序平移.旋转.缩放变换的方法 ...
- VC2008中如何为MFC应用程序添加和删除消息响应函数
最近重温<MFC Windows应用程序设计>第二版这本书,里面的代码全部是使用VC6.0写的,我Win7下安装的是VS2008开发环境. VC2008下添加和删除常见的消息响应函数有两种 ...
- Word2010制作倒福字
原文: https://www.toutiao.com/i6489772955797553677/ 选择"插入"选项卡,"插图"功能组,"形状&quo ...
- 摘记 史上最强大的40多个纯CSS绘制的图形(一)
今天在国外的网站上看到了很多看似简单却又非常强大的纯CSS绘制的图形,里面有最简单的矩形.圆形和三角形,也有各种常见的多边形,甚至是阴阳太极和网站小图标,真的非常强大,分享给大家. Square(正方 ...
- 史上最强大的40多个纯CSS绘制的图形
Square(正方形) #square { width: 100px; height: 100px; background: red; } Rectangle(矩形) #rectangle { wid ...
- 40多个纯CSS绘制的图形
本文由码农网 – 陈少华原创,转载请看清文末的转载要求. 今天在国外的网站上看到了很多看似简单却又非常强大的纯CSS绘制的图形,里面有最简单的矩形.圆形和三角形,也有各种常见的多边形,甚至是阴阳太极和 ...
- 用css3绘制你需要的几何图形
1.圆形 示例: 思路:给任何正方形元素设置一个足够大的 border-radius ,就可以把它变成一个圆形.代码如下: html: <div class="size example ...
随机推荐
- codeblocks无法编译的问题
(题外话:网上垃圾资源太多,良心推荐下载 codeblocks的码农们,别TM用DevC++,百度搜索100个不用devc++的理由加上我自己亲身经历!!!) https://jingyan.baid ...
- java的集合框架set 和map的深入理解
Java的集合框架之Map的用法详解 Map有两种比较常用的实现:HashMap 和 TreeMap. HashMap: HashMap 也是无序的,也是按照哈希编码来排序的,允许使用null 值和n ...
- SpringBoot初体验(续)
1.如果你还不知道SpringBoot的厉害之处,或者你不知道SpringBoot的初级用法,请移步我的上一篇文章,传送门 2.SpringBoot中的表单验证 所谓验证,无非就是检验,对比,正如ja ...
- 关于EsayUI中datagrid重复提交后台查询数据的问题
直接上代码: <table id="XXXX" style="width:100%;height:100%;" class="easyui-da ...
- Log4j – Log4j 2 API
Overview The Log4j 2 API provides the interface that applications should code to and provides the ad ...
- 桌面消息通知:HTML5 Notification
先上一段完整代码 //注册权限 Notification.requestPermission(function (status) { // 这将使我们能在 Chrome/Safari 中使用 Noti ...
- Webpack 入门教程
Webpack 是一个前端资源加载/打包工具.它将根据模块的依赖关系进行静态分析,然后将这些模块按照指定的规则生成对应的静态资源. 本章节基于 Webpack3.0 测试通过. 从图中我们可以看出,W ...
- [C#]使用Costura.Fody将源DLL合并到目标EXE
本文为原创文章,如转载,请在网页明显位置标明原文名称.作者及网址,谢谢! 一.本文主要是使用Costura.Fody工具将源DLL合并到目标EXE,因此,需要从以下任一链接下载: ①从Github地址 ...
- vue 集成 axios 发送post请求 payload导致后台无法接收到数据问题
vue 集成axios之后,发送的post请求默认为payload 方式. 如果想改为正常的方式,需要增加headers头,并且将发送是数据json格式改为 querystring的方式. 安装依赖 ...
- 添加无登录权限的SSH用户命令
useradd -M -s /sbin/nologin -n username passwd username userdel -r username