OJ---第一个只出现一次的字符

问题:找出一列字符串中只出现一次的字符,打印出第一个,如果没有,打印 “.”

方法解析:利用分割,要是重复出现,会将字符串分割为多分,只需要判断分割后的数组大小即可(98分)

关键:1.头,尾不相同,2。中间的数不能和头相同,不能和尾相同,也不能出现和前面,后面连续3.头部,尾部也不能出现连续(aasdsd/asasdd)(头,尾,连续)

import java.util.*;
public  class Main{
public static void main(String[] args){
Scanner sc=new Scanner(System.in);
while(sc.hasNext()){
String s=sc.nextLine();
System.out.print(onechar(s));
}
sc.close();
}
public static char onechar(String s){
char[] ch=s.toCharArray();
//容易忽略 asfasddf;
for(int i=0;i<ch.length;i++){
String[] subS=s.split(ch[i]+"");
//头,尾,连续  这三种情况




    if(i==0&&subS.length==1&&ch[0]!=ch[s.length()-1]&&ch[0]!=ch[1]){
    return ch[0];
    }else if(i==s.length()-1&&subS.length==1&&ch[0]!=ch[s.length()-1]&&ch[s.length()-1]!=ch[s.length()-2]){
    return ch[s.length()-1];
    }else if(i!=0&&i!=s.length()-1&&subS.length==2&&ch[i]!=ch[i-1]&&ch[i]!=ch[i+1]&&ch[i]!=ch[0]&&ch[i]!=ch[s.length()-1]){
    return ch[i];
    }




}
return '.';

}
}

方法二:

用两个for,或者迭代器,每个字符分别从头开始便利,出现一次,计数+1;(60分)

import java.util.*;
public  class Main{
public static void main(String[] args){
Scanner sc=new Scanner(System.in);
while(sc.hasNext()){
String s=sc.nextLine();
System.out.print(onechar(s));
}
sc.close();
}
public static char onechar(String s){
char[] ch=s.toCharArray();

for(int i=0;i<ch.length;i++){
	int k=0;
	for(int j=0;j<ch.length;j++){
		if(ch[i]==ch[j]){
			k++;
		}
		
	}
	if(k==1){
		return ch[i];
	}
	
}

return '.';

}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值