源代码:
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
char xx[50][80];
int maxline=0;
int ReadDat(void);
void WriteDat(void);
void StrOR(void)
{
inti,j,k;
int index,str;
char ch;
for(i=0;i<maxline;i++)
{
str=strlen(xx[i]);
index=str;
for(j=0;j<str;j++)
if(xx[i][j]=='o')
{
for(k=j;k<str-1;k++)
xx[i][k]=xx[i][k+1];
xx[i][str-1]=' ';
index=j;
j=0;
}
//非常好的算法,应该熟练掌握
for(j=str-1;j>=index;j--)
{
ch=xx[i][str-1];
for(k=str-1;k>0;k--)
xx[i][k]=xx[i][k-1];
xx[i][0]=ch;
}
}
}
void main()
{
system("CLS");
if(ReadDat())
{
printf("数据文件IN.DAT不能打开!\n\007");
return;
}
StrOR();
WriteDat();
}
int ReadDat(void)
{
FILE *fp;
int i=0;
char *p;
if((fp=fopen("IN.DAT","r"))==NULL) return 1;
while(fgets(xx[i],80,fp)!=NULL)
{
p=strchr(xx[i],'\n');
if (p)
*p=0;
i++;
}
maxline=i;
fclose(fp);
return 0;
}
void WriteDat(void)
{
FILE *fp;
int i;
system("CLS");
fp=fopen("OUT.DAT","w");
for (i=0;i<maxline;i++)
{
printf("%s\n",xx[i]);
fprintf(fp,"%s\n",xx[i]);
}
fclose(fp);
}