栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

JAVA练习题11

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

JAVA练习题11

package s1;

import java.util.Scanner;

//题目:将一个数组逆序输出。
public class Fs31 {
    public static void main(String[] args){
        System.out.println("请输入一个不多于10位的正整数");
        int [] a=new int[10];
        Scanner sc=new Scanner(System.in);

        for (int i= 0;i<10;i++){
            a[i]=sc.nextInt();}
        int temp=0;
        for (int i = 0;i <9;i ++){
            for (int j=0;j<9-i;j++){
                if (a[j]>a[j+1]){
                    temp  = a[j];
                    a [j]=a[j+1];
                    a[j+1]=temp ;
                }
            }
        }
        for (int i=9;i>=0;i--){
            System.out.print(" "+a[i]);
        }
    }
}

其他写法

public static void main(String[] args) { int[]arrA={1,3,44,22,77,99}; int[]arrB=newint[arrA.length]; int j=arrA.length; for (inti = 0; i < arrA.length; i++) { arrB[i]=arrA[j-1]; j--; } System.out.println("数组A逆序输出为:"+Arrays.toString(arrB)); }

package s1;
//题目:取一个整数a从右端开始的4~7位。
import java.util.Scanner;
public class Fs32 {
    public static void main(String[] args){
        System.out.println("请输入一个多于7位的正整数");
        Scanner sc=new Scanner(System.in);
        String [] a=sc.nextLine().split("");
        System.out.println("长度是:"+a.length);
        for(int i=a.length-1;i>=0;i--){
            if (a.length>=7){
                System.out.print(a[3]+a[4]+a[5]+a[6]);
                break;
            }else {
                System.out.println("输入长度不足7位");
            }
            }

        }
    }
其他写法
System.out.println("输入一个整数:");
 Scanner scanner=new Scanner(System.in); long num=scanner.nextLong();//获取输入
 String str=Long.toString(num);//把数字转化为String类型的
 char[]ch=str.toCharArray();//把String类型的字符,转化为char类型,每一个数字赋值到字符型数组中 
int n=ch.length;//字符型数组的长度 
System.out.println("该整数从右端开始的4-7位为:"+ch[n-7]+ch[n-6]+ch[n-5]+ch[n-4]);//输出结果 
scanner.close();//关闭输入流 }
package s1;

import java.util.Arrays;

//题目:打印出杨辉三角形(要求打印出10行如下图)
public class Fs33 {
    public static void main(String[] args) {
        int [][]a=new int[10][10];
        for (int i=0;i 

其他写法

程序分析:

1
  • 1

1 1

1 2 1
  • 1

1 3 3 1

1 4 6 4 1

1 5 10 10 5 1

1、二维数组的使用

2、第一列的数都是1

3、使用两个for循环,i控制行,j控制列;

从第二行第二列起arr[i][j]=arr[i-1][j-1]+arr[i-1][j]

public static void main(String[] args) {

    int[][]arr=newint[10][10];

    for (inti = 0; i < arr.length; i++) {

        arr[i][0]=1;//控制第一列的数等于1

   }

   for (inti = 1; i < arr.length; i++) {

       for (intj=1; j < arr.length; j++) {

          arr[i][j]=arr[i-1][j-1]+arr[i-1][j];//赋值

       }

   }

   //打印结果

   for (inti = 0; i < arr.length ; i++) {

       for (intk = arr.length-i;k>0;k--) {//空格的控制,为了好看

          System.out.print("  ");

       }

       for (intj = 0; j < arr.length; j++) {//打印出数组的数字

          if (arr[i][j]!=0) {//把把没赋值的零去掉

              System.out.print(arr[i][j]+"   ");

          }

       }

       System.out.println();//控制换行

   }

}

}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/345272.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号