华为机试: 参数解析、 字符逆序

1.参数解析

题目描述

在命令行输入如下命令:

xcopy /s c:\ d:\,

各个参数如下: 

参数1:命令字xcopy 

参数2:字符串/s

参数3:字符串c:\

参数4: 字符串d:\

请编写一个参数解析程序,实现将命令行各个参数解析出来。

解析规则: 

1.参数分隔符为空格 
2.对于用“”包含起来的参数,如果中间有空格,不能解析为多个参数。比如在命令行输入xcopy /s “C:\program files” “d:\”时,参数仍然是4个,第3个参数应该是字符串C:\program files,而不是C:\program,注意输出参数时,需要将“”去掉,引号不存在嵌套情况。
3.参数不定长 
4.输入由用例保证,不会出现不符合要求的输入 

输入描述:

输入一行字符串,可以有空格

输出描述:

输出参数个数,分解后的参数,每个参数都独占一行

示例1

输入

xcopy /s c:\\ d:\\

输出

4
xcopy
/s
c:\\
d:\\

a.本题虽然通过所有测试用例,但是感觉有问题,后期再来修改

import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		Scanner scanner=new Scanner(System.in);
		while(scanner.hasNext()){
			String string=scanner.nextLine();
			String str[]=string.split(" ");
			System.out.println(str.length);
			for(int i=0;i<str.length;i++){
				System.out.println(str[i]);
			}
		}
	}
}

2.字符逆序

题目描述

将一个字符串str的内容颠倒过来,并输出。str的长度不超过100个字符。 如:输入“I am a student”,输出“tneduts a ma I”。

输入参数:

inputString:输入的字符串 

返回值:

输出转换好的逆序字符串

输入描述:

输入一个字符串,可以有空格

输出描述:

输出逆序的字符串

示例1

输入

I am a student

输出

tneduts a ma I

a.算法1:直接从后往前输出

import java.util.Scanner;
public class Main{
	public static void main(String []args){
		Scanner scanner = new Scanner(System.in);
		String str=scanner.nextLine();
		for(int i=str.length()-1;i>=0;i--){
			System.out.print(str.charAt(i));
		}
	}
}

b:算法2:利用StringBuffer的reverse方法

import java.util.Scanner;

public class Main{
	public static void main(String []args){
		Scanner scanner = new Scanner(System.in);
		String str=scanner.nextLine();
		System.out.println(getRever(str));
	}
	
	public static String getRever(String s){
		StringBuffer sb=new StringBuffer();
		sb.append(s);
		return sb.reverse().toString();
	}
}

c:算法3:利用StringBuffer的setCharAt(i,ch)方法

import java.util.Scanner;

public class Main{
	public static void main(String []args){
		Scanner scanner = new Scanner(System.in);
		String str=scanner.nextLine();
		System.out.println(getRever(str));
	}
	
	public static String getRever(String s){
		StringBuffer stringBuffer = new StringBuffer();
		stringBuffer.append(s);
		int len=s.length();
		for(int i=0;i<len/2;i++){
			char temp=stringBuffer.charAt(i);
			stringBuffer.setCharAt(i, stringBuffer.charAt(len-1-i));
			stringBuffer.setCharAt(len-i-1, temp);
		}
		return stringBuffer.toString();
	}
}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值