传智杯 第六届—C

题目描述:

输入两个字符串,从第一字符串中删除第二个字符串中所有的字符。例如:第一个字符串是"They are students.",第二个字符串是"aeiou"。删除之后的第一个字符串变成"Thy r stdnts."。保证两个字符串的长度均不超过100。

输入描述:

输入两行,每行一个字符串。

输出描述:

输出删除后的字符串。

示例1

输入:

cpp 复制代码
They are students. 
aeiou

输出:

cpp 复制代码
Thy r stdnts.

解题思路:

在本题中,需要将b字符串包含的字符在a中都进行删除,所以可以设立两个字符数组,用于存储字符信息,然后利用两个for循环将b中所有的字符在a中查找出来,并进行标记,本次是将查找到的字符替换为'\\'即\,然后将替换过后的a字符数组中的非\字符提取出来到数组c中,这样就得到了想要的结果。

注意:

①本题是将所有b字符串包含的字符在a中都进行删除,不是进行字符串的匹配。

代码:

cpp 复制代码
#include<iostream>
#define MAX 101
using namespace std;
int main()
{
    int num_a = 0;   //记录字符串a的个数
    int num_b = 0;
    char a[MAX] = {'\0'};
    char b[MAX] = {'\0'};
    char ch;
    
    //输入字符串a
    for(int i=0;(ch=getchar()) != '\n';i++)   //表示输入不换行
    {
        a[i] = ch;
        num_a++;
    }
    //输入字符串b
    for(int i=0;(ch=getchar()) != '\n';i++)  
    {
        b[i] = ch;
        num_b++;
    }
    
    //查找
    for(int i=0;i<num_a;i++)
    {
        for(int j=0;j<num_b;j++)
        {
            if(a[i] == b[j])  //表示匹配成功
            {
                //将对应字符进行标记
                a[i] = '\\';
            }
        }
    }
    
    //将新字符串存储出来(删除被标记的字符)
    char c[MAX] = {'\0'};    //用于存储新的字符串
    int num_c = 0;
    for(int i=0;i<num_a;i++)
    {
        if(a[i] != '\\')
        {
            c[num_c++] = a[i];
        }
    }
    
    //输出
    for(int i=0;i<num_c;i++)
    {
        cout<<c[i];
    }
    
    system("pause");
    return 0;
}
相关推荐
星沁城10 分钟前
排序算法——堆排序:大根堆、小根堆
数据结构·算法·排序算法
tomcoding12 分钟前
排序算法总结(一)冒泡排序和选择排序
数据结构·排序算法
Mryan200525 分钟前
OpenJudge | 置换选择排序
开发语言·数据结构·c++·算法·排序算法·openjudge
milkve37 分钟前
王炸!MarsCode甄选算法题,面试官在力扣之外新选择(1)多米诺骨牌
人工智能·算法·面试
Bonne journée38 分钟前
python pass的作用
开发语言·python·算法
我命由我123451 小时前
5.Python 数据容器(list 列表、tuple 元组、str 字符串、set 集合、dict(字典)、序列切片)
数据结构·windows·笔记·python·学习·list·python3.11
Chris-zz1 小时前
Linux:进程调度算法和进程地址空间
linux·数据结构·c++·算法·哈希算法·散列表
小飞猪Jay1 小时前
C++面试速通宝典——21
c++·面试
Suhan421 小时前
【操作系统】四、文件管理:2.磁盘组织与管理(磁盘的结构、磁盘调度算法、磁盘的管理、虚拟文件系统VFS)
算法·硬件架构·硬件工程
shyshy老师1 小时前
实现一个时钟
c++·qt