how2j.cn

本视频是解读性视频,所以希望您已经看过了本知识点的内容,并且编写了相应的代码之后,带着疑问来观看,这样收获才多。 不建议一开始就观看视频



5分14秒
本视频采用html5方式播放,如无法正常播放,请将浏览器升级至最新版本,推荐火狐,chrome,360浏览器 如果装有迅雷,播放视频呈现直接下载状态,请调整 迅雷系统设置-基本设置-启动-监视全部浏览器 (去掉这个选项)



示例 1 : 是否是同一个对象   
示例 2 : 是否是同一个对象-特例   
示例 3 : 内容是否相同   
示例 4 : 是否以子字符串开始或者结束   
示例 5 : 练习-比较字符串   
示例 6 : 答案-比较字符串   

示例 1 :

是否是同一个对象

str1和str2的内容一定是一样的!
但是,并不是同一个字符串对象
package character; public class TestString { public static void main(String[] args) { String str1 = "the light"; String str2 = new String(str1); //==用于判断是否是同一个字符串对象 System.out.println( str1 == str2); } }
package character;

public class TestString {

	public static void main(String[] args) {

		String str1 = "the light";
		
		String str2 = new String(str1);
		
		//==用于判断是否是同一个字符串对象
		System.out.println( str1  ==  str2);
		
	}

}
示例 2 :

是否是同一个对象-特例


str1 = "the light";
str3 = "the light";

一般说来,编译器每碰到一个字符串的字面值,就会创建一个新的对象
所以在第6行会创建了一个新的字符串"the light"
但是在第7行,编译器发现已经存在现成的"the light",那么就直接拿来使用,而没有进行重复创建
package character; public class TestString { public static void main(String[] args) { String str1 = "the light"; String str3 = "the light"; System.out.println( str1 == str3); } }
package character;

public class TestString {

	public static void main(String[] args) {
		String str1 = "the light";
		String str3 = "the light";
		System.out.println( str1  ==  str3);
	}

}
示例 3 :

内容是否相同

使用equals进行字符串内容的比较,必须大小写一致
equalsIgnoreCase,忽略大小写判断内容是否一致
package character; public class TestString { public static void main(String[] args) { String str1 = "the light"; String str2 = new String(str1); String str3 = str1.toUpperCase(); //==用于判断是否是同一个字符串对象 System.out.println( str1 == str2); System.out.println(str1.equals(str2));//完全一样返回true System.out.println(str1.equals(str3));//大小写不一样,返回false System.out.println(str1.equalsIgnoreCase(str3));//忽略大小写的比较,返回true } }
示例 4 :

是否以子字符串开始或者结束


startsWith //以...开始
endsWith //以...结束
package character; public class TestString { public static void main(String[] args) { String str1 = "the light"; String start = "the"; String end = "Ight"; System.out.println(str1.startsWith(start));//以...开始 System.out.println(str1.endsWith(end));//以...结束 } }
package character;
 
public class TestString {
 
    public static void main(String[] args) {
        String str1 = "the light";
        
        String start = "the";
        String end = "Ight";
        
        System.out.println(str1.startsWith(start));//以...开始
        System.out.println(str1.endsWith(end));//以...结束
         
    }
 
}
示例 5 :

练习-比较字符串

Or  姿势不对,事倍功半! 点击查看做练习的正确姿势
创建一个长度是100的字符串数组
使用长度是2的随机字符填充该字符串数组
统计这个字符串数组里重复的字符串有多少种
练习-比较字符串
示例 6 :

答案-比较字符串

在查看答案前,尽量先自己完成,碰到问题再来查看答案,收获会更多
本视频是解读性视频,所以希望您已经看过了本答案的内容,带着疑问来观看,这样收获才多。 不建议一开始就观看视频

16分54秒 本视频采用html5方式播放,如无法正常播放,请将浏览器升级至最新版本,推荐火狐,chrome,360浏览器 如果装有迅雷,播放视频呈现直接下载状态,请调整 迅雷系统设置-基本设置-启动-监视全部浏览器 (去掉这个选项)


package character; public class TestString { public static void main(String[] args) { String[] ss = new String[100]; // 初始化 for (int i = 0; i < ss.length; i++) { ss[i] = randomString(2); } // 打印 for (int i = 0; i < ss.length; i++) { System.out.print(ss[i] + " "); if (19 == i % 20) System.out.println(); } for (String s1 : ss) { int repeat = 0; for (String s2 : ss) { if (s1.equalsIgnoreCase(s2)) { repeat++; if (2 == repeat) { // 当repeat==2的时候,就找打了一个非己的重复字符串 putIntoDuplicatedArray(s1); break; } } } } System.out.printf("总共有 %d种重复的字符串%n", pos); if (pos != 0) { System.out.println("分别是:"); for (int i = 0; i < pos; i++) { System.out.print(foundDuplicated[i] + " "); } } } static String[] foundDuplicated = new String[100]; static int pos; private static void putIntoDuplicatedArray(String s) { for (int i = 0; i < pos; i++){ if (foundDuplicated[i].equalsIgnoreCase(s)) return; } foundDuplicated[pos++] = s; } private static String randomString(int length) { String pool = ""; for (short i = '0'; i <= '9'; i++) { pool += (char) i; } for (short i = 'a'; i <= 'z'; i++) { pool += (char) i; } for (short i = 'A'; i <= 'Z'; i++) { pool += (char) i; } char cs[] = new char[length]; for (int i = 0; i < cs.length; i++) { int index = (int) (Math.random() * pool.length()); cs[i] = pool.charAt(index); } String result = new String(cs); return result; } }


HOW2J公众号,关注后实时获知布最新的教程和优惠活动,谢谢。


问答区域    
2018-06-17 交作业,用逆向思维解出的,详细解答
yzb2565295



解答是超详细的,但是我可能表述的不太清楚,希望能帮助大家
public class 比较字符串 {

	public static void main(String[] args) {
		//创建一个长度是100的字符串数组
		//使用长度是2的随机字符填充该字符串数组
		//统计这个字符串数组里重复的字符串有多少种 
		String str[] = new String[100];
		char[] c = getChar();
		for (int i = 0; i < str.length; i++) {
			str[i] =getS(c); 
		}
		int count =0;
		for (String  d : str) {//展示这个随机的str数组
			count++;
			// 每20个数换行
			if (count%20==0) {
				System.out.println(d);
			}else {
				System.out.print(d+" ");
			}		
		}
		//找重复的不好找,那就找不重复的
		//count1 表示唯一的字符串的个数,哪怕全都是重复的,那至少也有1种字符串
		int count1 =1;
		//第一层循环表示:数组中的每个字符串都遍历一遍
		for (int i = 0; i < str.length; i++) {
			//count2 表示每次第二层循环中不重复的个数,跳出第二层时自动归零。
			int count2=0;
			//第二层循环表示:从str[i]开始,依次和后面的字符串比较,所以下面的j是以i+1开始的
			for (int j = i+1; j < str.length; j++) {
				//如果str[i]和后面的某个字符串不是相同的字符串
				if (!(str[i].equals(str[j]))) {
					//就表示和str[i]不同的字符串多了一个了
					count2++;
				}else {
					//否者,这两个字符串就是相同的,输出并跳出当前循环
					System.out.println(str[i]);
					break;
				}
				//如果str[i]和它以后的所有字符串都不同,那么就表示这个字符串是唯一的,所以count++
				//count2从0开始的,而j是从i+1开始的,那么j到str.length共有str.length-1-i个字符串
				//那么count2 == str.length-1-i 就表示str[i]和它以后的所有字符串都不同
				if (count2 == str.length-1-i) {
					count1++;
				}
			}
		}
		//总数减去唯一的,就是重复的,解完!
		System.out.println("重复的有:"+(str.length-count1)+"种");
	}
	//获得一个由2个随机字符组成的字符串
	public static String getS(char[] c){
		String s;
		int index1= (int)(Math.random()*62);
		int index2= (int)(Math.random()*62);
		//通过随机得到的角标去char数组中得到对应的值,拼凑起来就是两个字符组成的字符串
		s = String.valueOf(c[index1])+String.valueOf(c[index2]);
		return s;
	}
	//获得一个由0-9,a-z,A-Z共62个字符组成的char类型字符数组
	public static char[] getChar(){
		char[] c = new char[62];
		int index = 0;
		for (int i = '0'; i <='9'; i++) {
			c[index] =(char) i;
			index++;
		}
		for (int i = 'a'; i <='z'; i++) {
			c[index] =(char) i;
			index++;
		}
		for (int i = 'A'; i <='Z'; i++) {
			c[index] =(char) i;
			index++;
		}
		return c;
	}

}

							






答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到





2018-06-06 交作业
夜的诗人



交作业
package 数字与字符串;

import java.util.Arrays;

public class TestString {
	public static String randomString(int length){
		char s[]=new char[length];
		for (int i = 0; i < s.length; i++) {
			char c=(char)((Math.random()*(126-33))+33);
			if(Character.isLetter(c)||Character.isDigit(c)){
				s[i]=c;
			}
			else{
				i--;
			}
		}
		String result=Arrays.toString(s);
		return result;
	}
	public static void main(String[] args) {
		String a[]=new String[100];
		for (int i = 0; i < a.length; i++) {
			a[i]=randomString(2);
		}
		int z=0;
		for(String ss:a){
			System.out.print(ss);
			z++;
			if(z==10){
				System.out.println();
				z=0;
			}	
		}	
		int x=0;
		for (int i = 0; i < a.length; i++) {
			for (int j = 1; j < a.length-i-1; j++) {
					if(i==j){
						break;
					}
					else if(a[i].equals(a[j])){
						x++;
						System.out.println("重复的字符串一共有"+x+"种,他们分别是"+a[i]);
					}
					
			}
		}
	}
}

							






答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到





2018-05-28 交作业
2018-05-22 哈哈哈可能也是一种奇葩写法
2018-05-12 我很想理解这个随机生成字符串的函数
2018-05-08 用集合解决
2018-04-25 【交作业】比较字符串
2018-04-22 作业
2018-04-20 统计字符串数组中相同元素出现的次数
2018-04-07 分析一下挺有意思的...我的残缺答案
2018-03-22 交作业,重复两遍就会输出两次
2018-03-21 作业 自己码的
2018-03-18 比较字符串作业
2018-03-04 作业题
2018-03-03 站长,有错误
2018-02-24 最后一题代码,没看答案自己码的。里面加了些注释,方便理解。不知道有没有错误,望指出
2018-02-23 最后一题的答案
2018-02-20 pos值是怎么来的
2018-02-14 最后一问:::通过(选择排序)的双层循环方法+字符串.contains()方法 很简单,欢迎指正。
2018-02-14 最后一问:::通过(选择排序)的双层循环方法+字符串.contains()方法 很简单,欢迎指正。
2018-02-01 有哪里能帮忙优化的不,感觉我的循环太多了。。
2018-01-29 自己没看答案写的。
2018-01-24 我这样可不可以,站长的那个后面代码有点看不太明白
2018-01-24 最后一个for循环问题!
2018-01-22 代码优化
2018-01-22 代码优化
2017-11-26 小试牛刀
2017-11-26 查重复的代码不知道怎么优化啊
2017-11-26 查找重复的算法不知道能不能优化写
2017-11-18 最后一个题的问题
2017-10-25 发一个最后一题的简单实现
2017-08-31 我的代码
2017-07-29 练习答案
2017-07-16 作业
2017-06-15 思路比较清晰,代码还算简单
2017-04-24 一起吃屎,一起喝尿!!!!
2017-04-14 为什么不用Map呢?会容易些
2017-04-07 我写的这样不知道如何,可能复杂度太高
2017-04-01 好像我的字符串数组没有重复
2017-03-29
2017-01-25 不看答案真的写不出来。。。对着答案还研究了半天
2016-06-07 希望能注释进一步讲解43行到52行代码作用。




提问之前请登陆
关于 JAVA 基础-数字与字符串-比较字符串 的提问

尽量提供截图代码异常信息,有助于分析和解决问题。 也可进本站QQ群交流: 620943819
提问尽量提供完整的代码,环境描述,越是有利于问题的重现,您的问题越能更快得到解答。
对教程中代码有疑问,请提供是哪个步骤,哪一行有疑问,这样便于快速定位问题,提高问题得到解答的速度
在已经存在的几千个提问里,有相当大的比例,是因为使用了和站长不同版本的开发环境导致的,比如 jdk, eclpise, idea, mysql,tomcat 等等软件的版本不一致。
请使用和站长一样的版本,可以节约自己大量的学习时间。 站长把教学中用的软件版本整理了,都统一放在了这里, 方便大家下载: http://how2j.cn/k/helloworld/helloworld-version/1718.html

上传截图