zoukankan      html  css  js  c++  java
  • L1-011. A-B(降低时间复杂度)

    L1-011. A-B

    时间限制
    100 ms
    内存限制
    65536 kB
    代码长度限制
    8000 B
    判题程序
    Standard
    作者
    陈越

    本题要求你计算A-B。不过麻烦的是,A和B都是字符串 —— 即从字符串A中把字符串B所包含的字符全删掉,剩下的字符组成的就是字符串A-B。

    输入格式:

    输入在2行中先后给出字符串A和B。两字符串的长度都不超过104,并且保证每个字符串都是由可见的ASCII码和空白字符组成,最后以换行符结束。

    输出格式:

    在一行中打印出A-B的结果字符串。

    输入样例:
    I love GPLT!  It's a fun game!
    aeiou
    
    输出样例:
    I lv GPLT!  It's  fn gm!


    这题目用java过不去,然后用c++,我刚开始想法是O(n*n)的解法,结果第2,4测试点是30ms,47ms,然后我看了一下别人的解法是O(n)的,发现很不错,提交第2,4测试点只有2ms了

    先是糟糕的解法:

    #include <bits/stdc++.h>
    using namespace std;
    char a[10001];
    char b[10001];
    bool flag;
    int main() // O(n*n)的解法很糟糕
    {
    	gets(a);
    	gets(b);
    	int len = strlen(a);
    	int len1 = strlen(b);
    	for (int i = 0; i < len; ++i)
    	{
            flag = true;
            for (int j = 0; j < len1; ++j)
    		{
                if (b[j] == a[i])
    			{
                    flag = false;
                    break;
                }
            }
            if (flag)
    		{
                putchar(a[i]);
            }
        }
        putchar('
    ');
    	return 0;
    }

    接着是O(n)的解法,推荐

    #include <bits/stdc++.h>
    using namespace std;
    char a[10001];
    char b[10001];
    char c[256];
    int main() // 推荐
    {
    	gets(a);
    	gets(b);
    	int len = strlen(a);
    	int len1 = strlen(b);
    	for (int i = 0; i < len1; ++i)
    	{
    		c[b[i]] = 1;
    	}
    	for (int i = 0; i < len; ++i)
    	{
    		if (!c[a[i]])	putchar(a[i]);
    	}
    	putchar('
    ');
    	return 0;
    }


    题目链接地址https://www.patest.cn/contests/gplt/L1-011

    ========================================Talk is cheap, show me the code=======================================

    CSDN博客地址:https://blog.csdn.net/qq_34115899
  • 相关阅读:
    HTTP状态码详解
    Django QuerySet 进阶
    初识Django
    小白学习之路,网络编程(下)
    小白学习之路,网络编程(上)
    小白学习之路,面向对象补充
    用正则表达式实现的计算器
    小白学习之路,初识面向对象
    小白学习之路,常用模块
    函数补充知识
  • 原文地址:https://www.cnblogs.com/lcy0515/p/9179785.html
Copyright © 2011-2022 走看看