Java中输入一个句子,去掉元音字母和双写的字母中的一个后输出的程序怎么写,求高手指教
Java中输入一个句子,去掉元音字母和双写的字母中的一个后输出的程序怎么写,求高手指教例子:PleaseenteraSentenceTheQuickBrownFoxAbb...
Java中输入一个句子,去掉元音字母和双写的字母中的一个后输出的程序怎么写,求高手指教例子:Please enter a Sentence The Quick Brown Fox Abbreviated String: Th Qck Brwn Fx Please enter a Sentence I like bananas Abbreviated String: I lk bns
展开
4个回答
展开全部
你好,代码我写好了,但是这句的结果和你的题意不符。
Please enter a Sentence I like bananas
Abbreviated String: I lk bns //根据题意nn是没有连着的,所以我认为结果是bnns
程序代码如下:如果你非要和上面的一样,那么将结果在递归一次就可以了。
import java.util.Scanner;
public class BaiduDemo {
public static String process(String str){
StringBuffer sb = new StringBuffer() ;
char[] c = str.toCharArray() ;
int i=1 ;
for(;i<c.length;i++){
if(c[i-1] != c[i]){
if(! isVowel(c[i-1])){
sb.append(c[i-1]) ;
}
}
}
sb.append(c[i-1]) ;
return sb.toString() ;
}
public static boolean isVowel(char c){
boolean flag = false ;
switch(c){
case 'a':
case 'o':
case 'e':
case 'i':
case 'u':
flag = true ;
break ;
default:
}
return flag ;
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in) ;
System.out.print("Please enter a Sentence: ") ;
String str = sc.nextLine() ;
System.out.println("Abbreviated String: " + process(str)) ;
}
}
Please enter a Sentence I like bananas
Abbreviated String: I lk bns //根据题意nn是没有连着的,所以我认为结果是bnns
程序代码如下:如果你非要和上面的一样,那么将结果在递归一次就可以了。
import java.util.Scanner;
public class BaiduDemo {
public static String process(String str){
StringBuffer sb = new StringBuffer() ;
char[] c = str.toCharArray() ;
int i=1 ;
for(;i<c.length;i++){
if(c[i-1] != c[i]){
if(! isVowel(c[i-1])){
sb.append(c[i-1]) ;
}
}
}
sb.append(c[i-1]) ;
return sb.toString() ;
}
public static boolean isVowel(char c){
boolean flag = false ;
switch(c){
case 'a':
case 'o':
case 'e':
case 'i':
case 'u':
flag = true ;
break ;
default:
}
return flag ;
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in) ;
System.out.print("Please enter a Sentence: ") ;
String str = sc.nextLine() ;
System.out.println("Abbreviated String: " + process(str)) ;
}
}
展开全部
思路是这个样子,以字符数组来看待字符串,然后挨个读取并判断,剔除不要,剩下的存到新的数组,最后再转为字符串
代码大致是这样:
string str = "Please enter a Sentence The Quick Brown Fox Abbreviated String: Th Qck Brwn Fx Please enter a Sentence I like bananas Abbreviated String: I lk bns";
char[] charsOld = str;
char prevC = charsOld[0];
char[] charsNew = new char[str.Length];
int j =0;
for(int i=1;i<str.Length;i++)
{
char c = charsOld[i];
if(c != prevC)
{
if(c!='a'&&c!='e'&&c!='i'&&c!='o'&&c!='u')
{
charsNew[j++] = c;
}
}
prevC = charsOld[i];
}
可能有部分语法问题,好久不写java了,但是大致思路都有了,你改改就好
代码大致是这样:
string str = "Please enter a Sentence The Quick Brown Fox Abbreviated String: Th Qck Brwn Fx Please enter a Sentence I like bananas Abbreviated String: I lk bns";
char[] charsOld = str;
char prevC = charsOld[0];
char[] charsNew = new char[str.Length];
int j =0;
for(int i=1;i<str.Length;i++)
{
char c = charsOld[i];
if(c != prevC)
{
if(c!='a'&&c!='e'&&c!='i'&&c!='o'&&c!='u')
{
charsNew[j++] = c;
}
}
prevC = charsOld[i];
}
可能有部分语法问题,好久不写java了,但是大致思路都有了,你改改就好
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
import java.util.Scanner;
/*
http://zhidao.baidu.com/question/340077325.html?seed=0
Java中输入一个句子,去掉元音字母和双写的字母中的一个后输出的程序怎么写,求高手指教例子:
Please enter a Sentence The Quick Brown Fox Abbreviated String: Th Qck Brwn Fx Please enter a Sentence I like bananas Abbreviated String: I lk bns
*/
public class Main2 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in) ;
for(;;){//便于测试加的一个无限循环,请测试后自行去掉
System.out.print("Please enter a Sentence: ") ;
String str = sc.nextLine() ;
System.out.println("Abbreviated String: " + fun(str)) ;
}
}
static String fun(String s){
String str=s;
str=str.replaceAll("a|e|i|o|u","");//去掉所有元音
char c[]=str.toCharArray();
str="";
int i=0;
str+=c[0];
for(int j=1;j<c.length;j++)
if(c[j]!=c[j-1])//如果是连续双子母只取其一
{
str+=c[j];i++;
}
return str;
}
}
java当然要有java特色么,放着String函数这么方便不用干啥啊,满足楼主的所有要求
/*
http://zhidao.baidu.com/question/340077325.html?seed=0
Java中输入一个句子,去掉元音字母和双写的字母中的一个后输出的程序怎么写,求高手指教例子:
Please enter a Sentence The Quick Brown Fox Abbreviated String: Th Qck Brwn Fx Please enter a Sentence I like bananas Abbreviated String: I lk bns
*/
public class Main2 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in) ;
for(;;){//便于测试加的一个无限循环,请测试后自行去掉
System.out.print("Please enter a Sentence: ") ;
String str = sc.nextLine() ;
System.out.println("Abbreviated String: " + fun(str)) ;
}
}
static String fun(String s){
String str=s;
str=str.replaceAll("a|e|i|o|u","");//去掉所有元音
char c[]=str.toCharArray();
str="";
int i=0;
str+=c[0];
for(int j=1;j<c.length;j++)
if(c[j]!=c[j-1])//如果是连续双子母只取其一
{
str+=c[j];i++;
}
return str;
}
}
java当然要有java特色么,放着String函数这么方便不用干啥啊,满足楼主的所有要求
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
刚看了一下,写了一个,不晓得符不符合要求:直接考出去就可以运行
public class test {
/*
* 去掉元音
*/
public static String delString(String str){
String str1=str.replace("a", "");
str1=str1.replace("e", "");
str1=str1.replace("i", "");
str1=str1.replace("o", "");
str1=str1.replace("u", "");
str1=str1.replace("A", "");
str1=str1.replace("E", "");
str1=str1.replace("I", "");
str1=str1.replace("O", "");
str1=str1.replace("U", "");
return str1;
}
/*
* 去掉双写
*/
public static char[] toChar(String str){
char[] c = new char[str.length()];
StringBuffer sb = new StringBuffer();
for(int i=0;i<str.length();i++){
c[i]=str.toCharArray()[i];
sb.append(c[i]);
}
return c;
}
public static String delDuble(char[] c){
StringBuffer sb = new StringBuffer();
for(int j=0;j<c.length-1;j++){
if(c[j]==c[j+1]){
c[j+1]='0';
}
}
for(int k =0;k<c.length;k++){
sb.append(c[k]);
}
return sb.toString().replace("0", "");
}
public static void main(String[] args) {
// TODO Auto-generated method stub
String aa= "ABCDEFGIUYYOOWWWaevgaeedfafdaf";
String bb=delString(aa);
char[] a=toChar(bb);
String b = delDuble(a);
System.out.println("转换前的结果--:"+aa);
System.out.println("转换后的结果--:"+b);
}
}
public class test {
/*
* 去掉元音
*/
public static String delString(String str){
String str1=str.replace("a", "");
str1=str1.replace("e", "");
str1=str1.replace("i", "");
str1=str1.replace("o", "");
str1=str1.replace("u", "");
str1=str1.replace("A", "");
str1=str1.replace("E", "");
str1=str1.replace("I", "");
str1=str1.replace("O", "");
str1=str1.replace("U", "");
return str1;
}
/*
* 去掉双写
*/
public static char[] toChar(String str){
char[] c = new char[str.length()];
StringBuffer sb = new StringBuffer();
for(int i=0;i<str.length();i++){
c[i]=str.toCharArray()[i];
sb.append(c[i]);
}
return c;
}
public static String delDuble(char[] c){
StringBuffer sb = new StringBuffer();
for(int j=0;j<c.length-1;j++){
if(c[j]==c[j+1]){
c[j+1]='0';
}
}
for(int k =0;k<c.length;k++){
sb.append(c[k]);
}
return sb.toString().replace("0", "");
}
public static void main(String[] args) {
// TODO Auto-generated method stub
String aa= "ABCDEFGIUYYOOWWWaevgaeedfafdaf";
String bb=delString(aa);
char[] a=toChar(bb);
String b = delDuble(a);
System.out.println("转换前的结果--:"+aa);
System.out.println("转换后的结果--:"+b);
}
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询