使用StringBuffer实现对于字符串 去除相邻连续的重复字符,然后输出。
2个回答
展开全部
public class Test3 {
public static void main(String[] args) {
String source = "abccdeefggh";
System.out.println("去除相邻连续的重复字符前:" + source);
source = func(source);
System.out.println("去除相邻连续的重复字符后:" + source);
}
public static String func(String source){
StringBuffer temp = new StringBuffer(source.substring(0,1));
int len = source.length();
int k = 0;
for(int i=1; i<len; i++){
if(source.substring(i,i+1).equals(temp.substring(k, k+1))){
continue;
}
temp.append(source.substring(i,i+1));
k++;
}
return temp.toString();
}
}
public static void main(String[] args) {
String source = "abccdeefggh";
System.out.println("去除相邻连续的重复字符前:" + source);
source = func(source);
System.out.println("去除相邻连续的重复字符后:" + source);
}
public static String func(String source){
StringBuffer temp = new StringBuffer(source.substring(0,1));
int len = source.length();
int k = 0;
for(int i=1; i<len; i++){
if(source.substring(i,i+1).equals(temp.substring(k, k+1))){
continue;
}
temp.append(source.substring(i,i+1));
k++;
}
return temp.toString();
}
}
展开全部
#include <stdio.h>
#include <string.h>
#define N 100
void main()
{
char a[N], b[N];
int i,n;
gets(a);
strcpy(b,a);
n=strlen(a);
for(i=0;i<n-1;i++)
if(a[i]==a[i+1])
a[i]=0;
for(i=n-1;i>0;i--)
if(b[i]==b[i-1])
b[i]=0;
for(i=0;i<n;i++)
if(a[i]!=b[i])
a[i]=0;
for(i=0;i<n;i++)
{
if(a[i]!=0)
printf("%c",a[i]);
else
;
}
putchar('\n');
}
#include <string.h>
#define N 100
void main()
{
char a[N], b[N];
int i,n;
gets(a);
strcpy(b,a);
n=strlen(a);
for(i=0;i<n-1;i++)
if(a[i]==a[i+1])
a[i]=0;
for(i=n-1;i>0;i--)
if(b[i]==b[i-1])
b[i]=0;
for(i=0;i<n;i++)
if(a[i]!=b[i])
a[i]=0;
for(i=0;i<n;i++)
{
if(a[i]!=0)
printf("%c",a[i]);
else
;
}
putchar('\n');
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询