第八周 项目3 顺序串算法

/*        
 *          烟台大学计算机与控制工程学院       
 *文件名称:sqstack.cpp       
 *作    者:王旭       
 *完成日期:2015年10月19日       
 *版 本 号:v1.0     
 *       
 *问题描述:采用顺序存储方式存储串,实现下列算法并测试: 
          实现将字符串S中所有值为c1的字符换成值为c2的字符: 
            void Trans(SqString *&s, char c1, char c2); 
          实现将已知字符串所有字符倒过来重新排列。如ABCDEF改为FEDCBA。 
            void Invert(SqString &s) 
          从串s中删除其值等于c的所有字符。如从message中删除’e’,得到的是mssag。 
            void DellChar(SqString &s, char c) 
          有两个串s1和s2,设计一个算法求一个这样的串,该串中的字符是s1和s2中公共字符。
            SqString CommChar(SqString s1,SqString s2);  
  
 *            
 *输入描述:无

 *程序输出:无
 */  

mian.cpp:

#include <stdio.h>
#include "sqString.h"
int main()
{
    SqString s;
    printf("实现将字符串S中所有值为c1的字符换成值为c2的字符:");
    StrAssign(s, "wangxu");
    Trans(s, 'e', 'a');
    DispStr(s);
    SqString s1;

    printf("实现将字符串反序:");
    StrAssign(s1, "abcdefg");
    Invert(s1);
    DispStr(s1);

    printf("从串s中删除其值等于g的所有字符:");
    StrAssign(s, "wangxu");
    DellChar(s, 'g');
    DispStr(s);

    printf("求公共字符:");
    SqString s2;
    StrAssign(s1, "wangxuqijq");
    StrAssign(s2, "ddgpwangxu");
    s = CommChar(s1, s2);
    DispStr(s);

    return 0;
}
SqString CommChar(SqString s1,SqString s2)
{
    SqString s3;
    int i,j,k=0;
    for (i=0; i<s1.length; i++)
    {
        for (j=0; j<s2.length; j++)
            if (s2.data[j]==s1.data[i])
                break;
        if (j<s2.length)            //s1.data[i]是公共字符
        {
            s3.data[k]=s1.data[i];
            k++;
        }
    }
    s3.length=k;
    return s3;
}
void DellChar(SqString &s, char c)
{
    int k=0, i=0;   //k记录值等于c的字符个数
    while(i<s.length)
    {
        if(s.data[i]==c)
            k++;
        else
            s.data[i-k]=s.data[i];
        i++;
    }
    s.length -= k;
}
void StrAssign(SqString &s,char cstr[]) //字符串常量cstr赋给串s
{
    int i;
    for (i=0;cstr[i]!='\0';i++)         //字符串常量cstr元素为空时终止
        s.data[i]=cstr[i];              //赋值
    s.length=i;                         //改变s的长度
}
void Trans(SqString &s, char c1, char c2)
{
    int i;
    for (i=0; i<s.length; i++)
        if (s.data[i]==c1)
            s.data[i]=c2;
}
void DispStr(SqString s)//输出串
{   int i;
    if (s.length>0)
    {
        for (i=0;i<s.length;i++)
            printf("%c",s.data[i]);
        printf("\n");
    }
}
void Invert(SqString &s)
{
    int i;
    char temp;
    for (i=0; i<s.length/2; i++)
    {
        temp = s.data[i];
        s.data[i]=s.data[s.length-i-1];
        s.data[s.length-i-1] = temp;
    }
}

sqString.h:

#ifndef SqString_H_INCLUDED
#define SqString_H_INCLUDED

#define MaxSize 100             //最多的字符个数
typedef struct
{   char data[MaxSize];         //定义可容纳MaxSize个字符的空间
    int length;                 //标记当前实际串长
} SqString;

void StrAssign(SqString &s,char cstr[]);    //字符串常量cstr赋给串s
void StrCopy(SqString &s,SqString t);   //串t复制给串s
bool StrEqual(SqString s,SqString t); //判串相等
int StrLength(SqString s);  //求串长
SqString Concat(SqString s,SqString t);  //串连接
SqString SubStr(SqString s,int i,int j); //求子串
SqString InsStr(SqString s1,int i,SqString s2); //串插入
SqString DelStr(SqString s,int i,int j) ;   //串删去
SqString RepStr(SqString s,int i,int j,SqString t);     //串替换
void DispStr(SqString s);   //输出串
void Trans(SqString &s, char c1, char c2);
void Invert(SqString &s);
void DellChar(SqString &s, char c);//从串s中删除其值等于c的所有字符
SqString CommChar(SqString s1,SqString s2);//求公共字符
#endif // LISTRING_H_INCLUDED

运行结果:




总结:编译时出现过error: expected initializer before ‘int’这个错误,

           后来发现是sqstring.h这个文件里边有一个自定义函数没有加分号,              

           但是很奇怪为什么错误不直接指在这里而是指到main.cpp文件里面。

           以后还要加倍细心--


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值