69,382
社区成员
发帖
与我相关
我的任务
分享
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
void fun(char* ch)//删除ch中被()中的串,无论有多少对(),()中的串都删了
{
int i;
char *p=NULL,*q=NULL,*r=ch;
while(*r!='\0') //从前向后找第一个'('
{
if(*r=='(')
{
p=r;
break;
}
r++;
}
if(p) //如果串有'('则从后向前找第一个')'
{
r=&ch[strlen(ch)-1]; //r指向最后一个元素
do
{
if(*r==')')
{
q=r;
break;
}
r--;
}while(r!=&ch[0]&&r!=p); //如果在找')'过程中先遇到p,则说明没有可配对的括号,q=NULL
}
if(p&&q) //如果最外层的'('')'都存在,则删除中间的串
strcpy(p,++q);
return;
}
void main()
{
char temp[100];
printf("input string:");
gets(temp);//输入一个串
fun(temp);//按要求删除
puts(temp);//再输出看看
system("pause");
}
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#define STACK_INIT_SIZE 100//栈的初始大小
#define STACKINCREMENT 10//栈每次增加的大小
struct Stack
{
char *base;
char *top;
int stacksize;
};
Stack *InitStack()//建立栈
{
Stack *s = (Stack*)malloc(sizeof(Stack));
s->base=(char *)malloc(STACK_INIT_SIZE*sizeof(char));
if(!s->base)exit(0);
s->top=s->base;
s->stacksize=STACK_INIT_SIZE;
return s;
}
void Push(Stack *s,char ch)//向栈顶插入元素
{
if(s->top-s->base>=s->stacksize)
{
s->base=(char *)realloc(s->base,(s->stacksize+STACKINCREMENT)*sizeof(Stack));
if(!s->base)exit(0);
s->top=s->base+s->stacksize;
s->stacksize+=STACKINCREMENT;
}
*s->top++=ch;
}
char Pop(Stack *s)//删除栈顶
{
char ch;
if(s->top==s->base)return 0;
ch=*--s->top;
return ch;
}
char Gettop(Stack *s)//返回栈顶元素
{
char e;
if(s->top==s->base)return NULL;
e=*(s->top-1);
return e;
}
void input(Stack *s)//对输入的/* */,(),[],{}进行处理
{
Stack *x=InitStack();
int flag1=0,flag2=0,flag3=0,flag=0;
char ch;
do
{
ch=getche();
if(ch==13)printf("\n");
if(ch==42&&Gettop(x)==47)flag=1;
if(flag==0&&ch==47&&Gettop(x)==42){printf("错误4");break;}
if(Gettop(x)!=42&&ch==47||Gettop(x)!=47&&ch==42)Pop(x);
if(flag==1&&ch==47&&Gettop(x)==42){flag=0;Pop(x);Pop(x);Pop(x);}
else
{
if(ch==42||ch==47)Push(x,ch);
}
if(ch==41&&Gettop(s)!=40){printf("1您的输入有误");break;}
if(ch==125&&Gettop(s)!=123){printf("2您的输入有误");break;}
if(ch==93&&Gettop(s)!=91){printf("3您的输入有误");break;}
if(ch==2&&Gettop(s)!=1){printf("3您的输入有误");break;}
if(ch==40||ch==123||ch==91)
Push(s,ch);
if(Gettop(s)==40&&ch==41)Pop(s);
if(Gettop(s)==123&&ch==125)Pop(s);
if(Gettop(s)==91&&ch==93)Pop(s);
}while(ch!='#');
}
void main()
{
Stack *s=NULL;
s=InitStack();
input(s);
}
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
void del(char *ch,char *p,char *q)//删除ch中p,q指向开始和结尾的子串
{
do
{
*(p++)=*(++q);
}while(*q!='\0');
}
void fun(char* ch)//删除ch中被()中的串,无论有多少对(),()中的串都删了
{
int i;
char *p=NULL,*q=NULL,*r=ch;
while(*r!='\0')
{
if(*r=='(')
p=r;
else if(*r==')')
{
if(p)
{
q=r;
del(ch,p,q);
p=NULL;
q=NULL;
r=ch;
}
}
r++;
}
return;
}
void main()
{
char temp[100];
printf("input string:");
gets(temp);//输入一个串
fun(temp);//按要求删除
puts(temp);//再输出看看
system("pause");
}
main()
{
char a[10];
scanf("%s",&a);
a[1]=')';
a[2]='\0';
printf("%s",a);
}