字符串包含引出来的“勤与懒”故事

简介:



今天给学生出了个题目,题目为:输入任意两个字符串,判断第一个字符串中是否包含第二个字符串。于是使引出了一个“勤与懒”的故事。

学生基本有两种状况,很短时间做出来的(这部分占大多数),很长时间做出来的(当然占小部分)。
公共部分:
Console .WriteLine(" 请输入第一个字符串:" );
            string str1 = Console.ReadLine();
            Console.WriteLine(" 请输入第二个字符串:" );
            string str2 = Console.ReadLine();
            if (str2.Length > str1.Length)
            {
                Console.WriteLine(" 一定不包含!" );
            }
先看一下短时间做出来的:
// 方法1
if  (str1.Contains(str2))
            {
                Console.WriteLine(" 包含" );
            }
            else
            {
                Console.WriteLine(" 不包含" );
            }
// 方法2
            if (str1.IndexOf(str2) != -1)
            {
                Console.WriteLine(" 包含" );
            }
            else
            {
                Console.WriteLine(" 不包含" );
        }
当然偷赖的方法还有许多,基本上就是简单应用字符串函数就能实现。
接下来看一下相对长时间的方法:
bool  mark = false;
            for (int i = 0; i < str1.Length - str2.Length; i++)
            {
                string temstr = "";
                for (int j = 0; j < str2.Length; j++)
                {
                    temstr += str1[i + j];
                }
                if (temstr == str2)
                {
                    mark = true;
                    break;
                }
            }
            if (mark)
            {
                Console.WriteLine(" 包含" );
            }
            else
            {
                Console.WriteLine(" 不包含" );
        }
这个方法相对来说还算厚道,因为拿str2总体作为一个单位,从str1的第一位开始切取,来与str2进行对比,这里没有直接用到字符串函数,整个例子,还算有点逻辑。
再看时间最长的:
            char[] ArrChar1 = str1.ToCharArray();
            char[] ArrChar2 = str2.ToCharArray();
            int tem2 = 0;// 临时的变量
            int lj = 0;// 记录匹配str2的累加器
            int lj2 = 0;// 记录str1比较的标志
            for (int i1 = lj2; i1 < ArrChar1.Length; i1++)
            {
                for (int i2 = tem2; i2 < ArrChar2.Length; i2++)
                {
                    if (ArrChar1[i1] == ArrChar2[i2])// 如果两个字符相等,就都指向下一个元素
                    {
                        tem2 = i2 + 1; // 标志str2再次比较的下标
                        lj++;          // 比较正确后累加器递增
                        if (lj == ArrChar2.Length) // 比较是否达到str2比较的最后
                        {
                            Console.WriteLine(" 包含" );
                            return;
                        }
                        break;
                    }
                    else
                    {
                        lj2++; // 记录str1比较到的位置
 
                        if (i1 == ArrChar1.Length - 1)// 查看是否比较到str1的最后
                        {
                            Console.WriteLine(" 不包含" );
                            return;
                        }
                        tem2 = 0;// 复位str2的比较
                        if (lj != 0) // 如果string2的累加器有数字,则退回到str1的前一位进行比较
                        {
                            i1 = i1 - 1;
                        }
                        lj = 0;//str1 累加器重新开始
                        break;
                    }
                }
            }
当然,代码看起来挺多,这个思路就是把字符串转成字符数组,常规的去比较第二个字符串是否在第一个中间,并且是按元素去比较的,可能说起来不难,但做起来还是有麻烦的点,关键就是在循环中间卡几个定位标志。
上面的三种情况,让我想到了“勤与懒”,前的学生偷了懒,用现成的函数完成了,后面的同学,相当于实现了这样一个函数。看起来前面的同学挺精明,用少量的代码完成了工作。但我相信,后面的同学则收获了更多。

如果现在是做项目,当然,“偷懒”的做法是可取的,但现在是做练习,就是练基本功,“勤快”点,对于提升和发展还是有好处的。一句话:“在适当的时候做适当的事”。




















本文转自桂素伟51CTO博客,原文链接:http://blog.51cto.com/axzxs/357214 ,如需转载请自行联系原作者






相关文章
|
1月前
|
算法 前端开发 数据处理
小白学python-深入解析一位字符判定算法
小白学python-深入解析一位字符判定算法
48 0
|
PHP 开发者
|
Java 程序员 索引
我终于把Python中下划线的含义弄清楚了(憋了很久了)
我终于把Python中下划线的含义弄清楚了(憋了很久了)
|
存储 Java 索引
1760字,让你拿捏 [‘列表‘]
1760字,让你拿捏 [‘列表‘]
|
缓存 自然语言处理 小程序
这个迭代写了个小程序,顺便整理了一份笔记 📒 (4000字)
这个迭代写了个小程序,顺便整理了一份笔记 📒 (4000字)
199 0
|
Java
第五期:字符串的一些有意思的操作
第五期:字符串的一些有意思的操作
91 0
|
运维 Shell
善用chatGPT学习 | bash脚本如何判断字符串在数组中
善用chatGPT学习 | bash脚本如何判断字符串在数组中
202 0
笔者记不住的一些注意事项和一些操作符的运用与君分享(基础C)
笔者记不住的一些注意事项和一些操作符的运用与君分享(基础C)
笔者记不住的一些注意事项和一些操作符的运用与君分享(基础C)
|
存储 SQL 缓存
震惊,99.9% 的同学没有真正理解字符串的不可变性
稍有些基础的同学都知道 Java 中 String 字符串是“不可变”的,想要使用“可变字符串”可以使用 `StringBuilder` 和 `StringBuffer` 。 大多数讲字符串不可变性的文章大同小异。但实际上大多数人的理解并不对。
171 0
震惊,99.9% 的同学没有真正理解字符串的不可变性
|
Java 程序员 Linux
Python仅用3行代码就能输出花式字符串图集,同事直呼666!
相信Java程序员看到上面的图,一定不会陌生。没错,springboot的启动日志。不知道其他人怎么想,我第一次看到这个启动日志的时候,就觉得好炫酷。然而,大家在日常的Python开发中,日志打印的却枯燥无比。今天就来教大家打印出让同事羡慕,却让领导崩溃的代码输出。
418 0