本文目录一览:
- 1、java for循环输出金字塔
- 2、怎样用JAVA打印出下面下列数字金字塔
- 3、java输出如下的金字塔形的数字
- 4、java打印金字塔数字,1.2.4.8.16.....这样的数表用for语句应该怎么写啊
- 5、怎么用java打印金字塔
- 6、编写空心菱形金字塔的java程序
java for循环输出金字塔
每行三部分,前面的空格,中间星号,找出行号跟数量的关系,后面加个换行符。
假设第四行前面一个空格,那么第三行是两个空格,第二行是三个,第一个行是四个。
设行号是X,所以空格数量跟行号的关系是:5-X。
星号的数量就等于:1+(X-1)*2
for(int i=1; i=4; i++) //最外层for控制第一到第四行输出
{
for(int j=1; j=5-i; j++){ //控制每行开头的空格输出数量
System.out.print(" ");
}
for(int k=1; k=1+(i-1)*2; k++) //控制接着空格后面输出的星号数量
{
System.out.print("*");
}
System.out.print("\n"); //每行前两部分输出完了后,输出一个换行符换到下一行。
}
怎样用JAVA打印出下面下列数字金字塔
这是我看到的第三个相同的问题了
先给你讲思路吧,首先这是个三角形,用3个FOR循环打印,一个控制行,一个控制前面的空格,一个控制后面打的东西。
如:
for(){//控制行数
for(){//控制每行前面的空格
}
for(){//控制每行所打的东西
}
}
例如光打个三角形的,不管里面的数字,那就这样:
for(int hang=0;hang6;hang++){//控制行(hang)
for(int kongge=0;konggehang;kongge++){//控制前面空格
System.out.print(" ");
}
for(int neirong=6;neironghang;neirong--){//控制内容
System.out.print("*");
}
System.out.println();//打印完一行换行
}
第三个FOR循环里面的neironghang(这个变量可以自己定,表示有对少内容,这个是大于行数,由行数来决定,因为行数循环一次增加一次,则内容就减少一个)
上面是每打一行,则少一个内容,而你的题目是少两个,你数数,你的第一行有11个,第二就有9个了。
那就这样:
int nr=11;//定义控制内容个数的变量nr
for(int hang=0;hang6;hang++){//控制行
for(int kongge=0;konggehang;kongge++){//控制空格
System.out.print(" ");
}
for(int neirong=nr;neirong0;neirong--){//看,内容等于nr
System.out.print("*");
}
nr=nr-2;//每循环完一次,nr减少2;
System.out.println();
}
看到了么第三个for循环里的neirong0,我写的是0,也可以的,意思内容由nr决定,第一次循环是11个数字,结束后nr-2,下一次循环就是9个数字了,以此类推
------------
好了,现在形状已经打印出来了,那就把里面的*改成变化的数字就可以了。首先你的数字是先是以3的倍数增加,然后到中间后,以3的倍数减少。你数数,每行都是从最中间开始变的,中间那个数最大。
那首先我想到的是写两个方法,一个乘,一个除。
一下是两个方法:
public static int cheng(int num1){
num1=num1*3;
if(num1==0){
num1=1;
}
return num1;
}
public static int chu(int num1){
num1=num1/3;
return num1;
}
现在方法写了,我们直接带入进去就好了;
我给全部代码:
public class San {//类名三
public static int cheng(int num1){//静态乘法方法
num1=num1*3;//带入的参数乘3
if(num1==0){//判断如果参数是0,则直接返回1
num1=1;
}
return num1;//返回结果
}
public static int chu(int num1){//静态方法除法
num1=num1/3;//参数直接除以3
return num1;//返回结果
}
public static void main(String[] args) {//程序入口main方法
int nr=11;//定义初始内容个数,11个
for(int hang=0;hang6;hang++){//第一个FOR循环,控制行
int chushi=0;//上面两个参数的初始值0
for(int kongge=0;konggehang;kongge++){//控制空格
System.out.print("\t");//打印空格
}
for(int neirong=nr;neirong0;neirong--){//控制内容
int zhongjian=0;//定义最中间的数
if(nr%2!=0){//内容个数除2有余,则除2+1
zhongjian=nr/2+1;
}else{//内容没有余数,则直接除2
zhongjian=nr/2;
}
if(neirong=zhongjian){//如果内容个数大于中间数,则实行乘法
System.out.print(cheng(chushi)+"\t");
chushi=cheng(chushi);
}else{//如果内容小于中间数,则实行除法
System.out.print(chu(chushi)+"\t");
chushi=chu(chushi);
}
}
nr=nr-2;//换行,内容个数减少2个
System.out.println();//换行
}
}
}
--------------------------
不知道你明白没。
上面的中间数意思是说告诉程序哪里开始递减。
比如第一行,有11个数字,到第6个数的时候停止再乘3,转向除3,
那怎么得到6?那就用11/2,而这样只能得到5,所以我上面用了判断,如有有余数的话,就加上1,那中间数就得到6了,如果没余数,就直接除2,第二行就是10/2,得到了5,你看看中间是不是第5个丫。
下面我判断如果neirong=zhongjian如果内容大于中间数的话,就执行乘法,不大于就执行除法。
用实际例子说明:你的例子第一行,有11个数,
那就是
1 3 9 27 81 243 81 27 9 3 1
11 10 9 8 7 6 5 4 3 2 1
6以前的都是执行乘法,5以后的都是执行的除法饿。
你自己在仔细看看吧
刚看了这个问题,临时想的方法,可能不怎么好,但是你也可以看一看。
java输出如下的金字塔形的数字
import java.util.Scanner;
public class Exe_19 {
public static void main(String[] args){
System.out.print("请输入一个的数字:");
Scanner input = new Scanner(System.in);
int a = input.nextInt();
for (int i = 1; i = a;i++){
for (int j = 0; j a - i;j++ )//打印空格
System.out.print(" ");
for (int k = 1; k = i ;k++)
System.out.printf("%3.0f",Math.pow(2,(k - 1)));//打印左半边
for (int q = i;q 1;q--)
System.out.printf("%3.0f",Math.pow(2,(q - 2)));//打印右半边
System.out.print("\n");
}
}
}
java打印金字塔数字,1.2.4.8.16.....这样的数表用for语句应该怎么写啊
class Ideone
{
public static void main (String[] args) throws java.lang.Exception
{
int a=10;
for(int i=1,int s=1,int a=10;i==a;i++,i=2*i) System.ouprintln(i);
// your code goes here
}
}
怎么用java打印金字塔
public class work2 {
public static void main(String[] args) {
method(9);
}
//参数化控制行数
public static void method(int n){
for(int i = 1;i = n;i++){
//每行打印的空格
for(int j = 1;j = n - i;j++){
System.out.print(" ");
}
//每行打印的*
for(int k = 1;k = 2 * i - 1;k++){
System.out.print("*");
}
System.out.println();
}
}
}
编写空心菱形金字塔的java程序
空心菱形金字塔的Java程序如下:
public class Test6 {
public static void main(String[] args) {
final int N=5;
for (int i = 1; i = N*2-1; i++) {
for (int j = 1; j = Math.abs(N - i); j++) {
System.out.print(" ");
}
for (int k = 1; k = 2*N-1-Math.abs(i-N)*2; k++) {
if(k==1 || k == 2*N-1-Math.abs(i-N)*2)
System.out.print("*");
else
System.out.print(" ");
}
System.out.println();
}
}
}
运行结果:
*
* *
* *
* *
* *
* *
* *
* *
*