单词排序 --- lintcode 819

点击打开题目

上面的超链接链向原题,原题的题意是给定新的字母表,让我们用新字母表的顺序给给定的字符串按照字典排序法排序。


思路:

其实题意就是字母的一对一替换,将得到的字符串用原来的字母表示出来,将结果进行排序后,反编译回现在的字母表示即可。


代码如下:

public class Solution {
    /**
     * @param alphabet: the new alphabet
     * @param words: the original string array
     * @return: the string array after sorting
     */
    public String[] wordSort(char[] alphabet, String[] words) {
		String[][] temp = new String[words.length][2];
		for (int i = 0; i < temp.length; i++) {
			temp[i][0] = words[i];
			temp[i][1] = calculate(words[i], alphabet);
		}

		Arrays.sort(temp, new Comparator<String[]>() {

			public int compare(String[] s1, String[] s2) {
				if (s1[1].startsWith(s2[1])) {
					return 1;
				}
				if (s2[1].startsWith(s1[1])) {
					return -1;
				}

		    	for (int i = 0; i < s1[1].length() && i < s2[1].length(); i++) {
					char c1 = s1[1].charAt(i);
					char c2 = s2[1].charAt(i);
					if (c1 != c2) {
						if (c1 > c2) {
							return 1;
						} else {
							return -1;
						}
					}
				}
				return 0;
			}

		});

		String[] ret = new String[temp.length];
		for (int i = 0; i < ret.length; i++) {
			ret[i] = temp[i][0];
		}
		return ret;
	}

	private String calculate(String string, char[] alphabet) {
		String normal = "abcdefghijklmnopqrstuvwxyz";
		String unusual = new String(alphabet);
		StringBuilder strb = new StringBuilder();

		int index;
		for (int i = 0; i < string.length(); i++) {
			index = unusual.indexOf(string.charAt(i));
			strb.append(normal.charAt(index));
		}

		return strb.toString();
	}
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: pta7-5是一个任务,要求对一系列英文单词进行排序。在进行单词排序时,我们可以按照字母顺序进行排序,这样可以更直观地呈现出单词顺序。首先,我们需要将所有的英文单词按照字母顺序进行排列,可以使用字母表作为排序的参考。其次,对于开头相同的单词,我们可以再根据第二个字母的顺序进行排序。依此类推,对于更多字母相同的单词,我们可以按照第三个、第四个字母以此类推进行排序。最后,将排序后的单词逐一列出,即可完成pta7-5任务。在实际操作时,我们可以使用计算机编程语言中的排序算法来完成这个任务,如使用Python语言中的sorted()函数。通过这个函数,我们可以很方便地对一批英文单词进行排序,并输出排序后的结果。完成排序后,你将得到一系列按照字母顺序排列的英文单词列表,如["apple","banana","cat","dog","elephant"]。这样的排序结果对于后续的数据分析和处理工作非常有用,也能更好地展示出单词之间的关系和规律。总之,pta7-5的任务要求我们对英文单词进行排序,通过使用排序算法和计算机编程语言,我们可以高效地完成这个任务。 ### 回答2: pta7-5是一个英文单词排序题目。要求将一串英文单词按字母顺序进行排序。 首先,我们需要将这些单词拆分成一个个独立的单词。然后,我们可以使用任何一种有效的排序算法来对这些单词按字母顺序进行排序。 一种常用的排序算法是冒泡排序。冒泡排序的基本思想是依次比较相邻的两个元素,如果它们的顺序不对就交换它们的位置,直到整个序列都有序为止。 假设给定的一串英文单词为:apple, banana, orange, cat, dog 按照冒泡排序的步骤,首先比较相邻的两个单词,如果顺序不对就交换它们的位置: apple, banana, orange, cat, dog (原始顺序) banana, apple, orange, cat, dog (比较apple和banana,发现顺序不对,交换位置) banana, apple, orange, cat, dog (比较banana和orange,顺序正确,不交换位置) banana, apple, orange, cat, dog (比较orange和cat,顺序正确,不交换位置) banana, apple, cat, orange, dog (比较cat和dog,发现顺序不对,交换位置) 第一次排序完成后,最大的单词dog会出现在最后的位置。 按照同样的步骤,再次进行排序: banana, apple, cat, orange, dog (比较banana和apple,顺序正确,不交换位置) banana, apple, cat, orange, dog (比较apple和cat,顺序正确,不交换位置) banana, apple, cat, orange, dog (比较cat和orange,顺序正确,不交换位置) banana, apple, cat, dog, orange (比较orange和dog,发现顺序不对,交换位置) 再次排序完成后,第二大的单词orange会出现在倒数第二的位置。 按照同样的步骤,继续进行排序: banana, apple, cat, dog, orange (比较banana和apple,顺序正确,不交换位置) banana, apple, cat, dog, orange (比较apple和cat,顺序正确,不交换位置) banana, apple, cat, dog, orange (比较cat和dog,顺序正确,不交换位置) banana, apple, cat, dog, orange (比较dog和orange,顺序正确,不交换位置) 最后一次排序完成后,剩下的单词已经按照字母顺序进行排序。 最终的排序结果为:apple, banana, cat, dog, orange。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值