JavaAPI试题练习

1、题目一:计算出现次数和位置

1.1 问题描述

编写程序统计一个字符子串在一个字符串中出现的次数和位置。如子字符串“nba”在字符串”asfasfnabaasdfnbasdnbasnbasdnbadfasdf”中出现的次数和出现的位置。

1.2 解题思路

需要运用到String类的几个常用方法

indexOf(ch)  //用于返回指定子串“ch”在字符串中第一次出现的位置

contains() //用于判断字符串中是否包含指定的字符或字符串。

substring(int beginIndex) //用于返回新字符串,包含一个参数beginIndex,表示从beginIndex开始到结尾结束

具体使用方法见代码 

1.3 运行代码

public class wmj4_1 {
    //创建寻找出现次数和出现位置的函数,导入参数字符串和要寻找的字符
    public static void main(String[] args){
        String str="asfasfnabaasdfnbasdnbasnbasdnbadfasdf";
        String key="nba"; //需要查找的子串
        int count=1; //出现的次数
        int index,index1=0; //下标
        int n=1;  //用于显示每次出现
        //首先判断子串是否在字符串中
        if(str.contains(key)){
            //如果下标等于第一次出现的子串,并且不等于-1
            while((index=str.indexOf(key))!=-1){
                //返回一个新字符串,从找到的第一个子串后开始到结束
                str=str.substring(index+key.length());
                //输出当前的位置
                System.out.println("第"+(n++)+"次出现的位置是:"+(index+index1));
                index1=(index+index1+key.length()); //因为substring会返回新的列表,用index1来记录原来的下标
                count++;
            }

        }
        System.out.println("统计:字符串nba一共出现了"+count+"次");	
    }
    
}

1.4 运行结果

第1次出现的位置是:14
第2次出现的位置是:19
第3次出现的位置是:23
第4次出现的位置是:28
统计:字符串nba一共出现了5次

如果不保存原来的下标操作,结果会是这样的:

2、题目而:计算出现次数和位置

2.1 问题描述

对字符串“23 10 -8 0 3 7 108”中的数值进行升序排序,生成一个数值有序的字符串 “-8 0 3 7 10 23 208”。

2.2 解题思路

需要运用到StringBuilder类的几个常用方法

具体使用方法见代码 

2.3 运行代码

import java.util.Arrays;

public class wmj4_2 {
    private static final String SEPARATOR=" ";
    public static void main(String[] args){
        String numstr="23 10 -8 0 3 7 108";
        String numstrs=SortNumberString(numstr);
        System.out.println(numstrs);
    }
    private static String SortNumberString(String numstr) {
        //将字符串转换为多个数字格式的字符串数组
        String[] numbers=toStringArray(numstr);
        int[] numint=toIntArray(numbers);
        sort(numint);
        return toString(numint);
    }
    private static String toString(int[] numint){
        StringBuilder sb=new StringBuilder();
        for(int i=0;i<numint.length;i++){
            //判断是否为最后一行
            if(i!=numint.length-1){
                sb.append(numint[i]+SEPARATOR);
            }
            else{
                sb.append(numint[i]);
            }
        }
        return sb.toString();
    }
    private static void sort(int[] numint){
        Arrays.sort(numint);
    }
    private static int[] toIntArray(String[] numbers){
        int[] numint=new int[numbers.length];
        for(int i=0;i<numbers.length;i++){
            numint[i]=Integer.parseInt(numbers[i]);
        }
        return numint;
    }
    private static String[] toStringArray(String numstr){
        return numstr.split(SEPARATOR);
    }
    
}

2.4 运行结果

-8 0 3 7 10 23 108

2、题目而:计算出现次数和位置

3.1 问题描述

对字符串“23 10 -8 0 3 7 108”中的数值进行升序排序,生成一个数值有序的字符串 “-8 0 3 7 10 23 208”。

3.2 解题思路

需要运用到StringBuilder类的几个常用方法

具体使用方法见代码 

3.3 运行代码

import java.io.IOException;
import java.util.*;
import java.util.Scanner;

public class wmj4_3 {
    public static void main(String[] args){
        //输入
        Scanner sc=new Scanner(System.in);
        //获取当前系统属性
        Properties pp=System.getProperties();
        //获取当前应用程序的运行环境对象
        Runtime rt=Runtime.getRuntime();

        String tmp=null;
        while(true){
            System.out.println("请选择操作 【请用大写字母】:");
            System.out.println("*************************************");
            System.out.println("A:记事本");
            System.out.println("B:重启计算机");
            System.out.println("C:启动QQ");
            System.out.println("D:查看系统操作");
            System.out.println("G:退出");

            tmp=sc.next();
            if(tmp.equals("A")){
                try{
                    rt.exec("notepad.exe");
                }catch(IOException e){
                    e.printStackTrace();
                }
            }
            else if(tmp.equals("B")){
                try{
                    rt.exec("shutdown -r");
                }catch(IOException e){
                    e.printStackTrace();
                }
            }
            else if(tmp.equals("C")){
                try{
                    rt.exec("D:\\Program Files\\tencent\\QQ\\Bin\\QQScLauncher.exe");

                }catch(IOException e){
                    e.printStackTrace();
                }
            }

            else if(tmp.equals("D")){
                
                    Enumeration ee=pp.propertyNames();
                    while(ee.hasMoreElements()){
                        //获取系统属性的key
                        String key=(String)ee.nextElement();
                        String value=System.getProperty(key);
                        System.out.println(key+"--->"+value);
                    }
            }
            else if(tmp.equals("G")){
                break;
            }

        }



    }
}

 3.4 运行结果

请选择操作 【请用大写字母】:
*************************************
A:记事本
B:重启计算机
C:启动QQ
D:查看系统操作
G:退出
D
java.runtime.name--->Java(TM) SE Runtime Environment
sun.boot.library.path--->E:\Java base\jdk\jre\bin
java.vm.version--->25.291-b10
java.vm.vendor--->Oracle Corporation
java.vendor.url--->http://java.oracle.com/
path.separator--->;
java.vm.name--->Java HotSpot(TM) 64-Bit Server VM

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值