Pig Latin儿童黑话(java)
●假设单词以辅音字母開始,将词首的辅音字母字符串(第一个元音字母前的全部字母)从单词的开头移动到末尾,然后加上后缀ay,这样就形成了它的pig latin。
●假设单词以元音字母開始,仅仅须要加入后缀way就可以。
这里注意java中的分离思想,对于这样的问题,我们一眼想不出解决的方法的时候,我们就要把它分解成多个小问题;
对于这个问题:
首先,我们会想推断它的第一个字母是不是元音字母,引申为查找它的第一个元音字母的位置,找到就返回它的位置,在这里还有推断它是否是一个英语单词,假设是而且第一个为元音字母的话,我们就在后面加入后缀返回,假设没有元音字母就直接返回原英语单词,假设元音字母在中间的话就将词首的辅音字母字符串从单词的开头移动到末尾,再加上后缀ay,然后返回。
这里又涉及到了一个字符串的分离问题,假设是一篇文章,一段话的话,肯定不会仅仅有一个单词,所以,我们就要把他们分离成一个单词,然后再进行推断再进行处理。
到这里,我们的问题就分成了5个小问题:
1.找出第一个元音字母的位置;
2.对字母进行推断(看是不是元音字母);
3.推断是不是一个英语单词;
4.转换一段文字(把一段文字分离成一个一个单词);
5.转换一个单词(对单词进行处理,加入后缀)
以下是我的代码(參考了老师的代码)
主方法:
package com.whj.PigLatin; import java.util.Scanner;
import java.util.StringTokenizer; public class Test { private static String DELIMITERS ="`~!@#$%^&*()<>?:[]{}_-+=?.,';"; //这里设置的是一个常量,用于分离的(仅仅要遇到这些字符,两个单词就会分离;
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);//从键盘输入
String line=scanner.nextLine();
System.out.println(translateLine(line));
}
转换文字的方法(对一段文字进行分离):
这里用到了分离单词的这个类,在上个实验中也用到了继承与多态 的第二个实验:
private static String translateLine(String line) {
String result=" ";
StringTokenizer tokenizer=new StringTokenizer(line,DELIMITERS,true);//这个分离用到的一个类
while(tokenizer.hasMoreTokens())//推断hasMoreTokens()方法是否有返回值(看有没有下一个匹配的字段)
{
String token=tokenizer.nextToken();//nextToken() 用于返回下一个匹配的字段
if(isWord(token))
{
token=tramslateWord(token);
}
result +=token;
}
return result;
}
转换一个单词,对单词进行处理,依照题意要求:
private static String tramslateWord(String token) {
int local=firstvowel(token);
if(local==-1)
return token;
else if(local==0)
return token+"way";
else
{
String head=token.substring(0,local);//这里用到了一个字符串的分离方法(间隔)
String middle=token.substring(local);
return middle+head+"ay";
}
}
查找第一个元音字母的位置:
private static int firstvowel(String token) {
for(int i=0;i<token.length();i++)
if(isEnglishvowel(token.charAt(i)))//charat(i)相当于数组 a[i](比喻可能有点不恰当)
return i;
return -1;
}
推断是不是元音字母:
private static boolean isEnglishvowel(char ch) {
switch(Character.toLowerCase(ch)){
case 'a':
case 'e':
case 'i':
case 'u':
case 'o':
return true;
default: return false;
}
}
推断是不是英语单词:
private static boolean isWord(String token) {
for(int i=0;i<token.length();i++)
if(!Character.isLetter(token.charAt(i)))
return false;
return true;
}
}
这个题目涉及到了几个比較重要的java中的类比方:StringTokenizer(字符串的分离方法在这个类中),Character(把大写字母变为小写,小写变大写,推断是不是字符),
String(分隔一个字符串),这几个类中都要非常多的字符串处理的方法,有待我们去学习利用,java的学习就是要灵活的运用这些类,熟悉里面的方法;
字符串的处理真的是一个比較重要的模块,事实上我们如今的非常多操作都是基于字符串的操作,并且好像面试中一般也都会涉及字符串的题目,对这个模块还是要好好掌握,这方面的知识还有非常多,自己还要慢慢的积累。
Pig Latin儿童黑话(java)的更多相关文章
- Pig latin基础
pig的两种运行模式,local模式,mapreduce模式 local模式下,pig只能访问本地一台:在mapreduce模式下,pig可以访问一个hadoop集群和hdfs的安装位置.这时,pig ...
- 20190118-利用Python实现Pig Latin游戏
1.利用Python实现Pig Latin字母游戏 “Pig Latin”是一个英语儿童文字改写游戏,整个游戏遵从下述规则:a. 元音字母是‘a’.‘e’.‘i’.‘o’.‘u’.字母‘y’在不是第一 ...
- Pig Latin程序设计1
Pig是一个大规模数据分析平台.Pig的基础结构层包括一个产生MapReduce程序的编译器.在编译器中,大规模并行执行依据存在.Pig的语言包括一个叫Pig Latin的文本语言,此语言有如下特性: ...
- LeetCode算法题-Goat Latin Easy(Java实现)
这是悦乐书的第322次更新,第344篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第192题(顺位题号是824).给出句子S,由空格分隔的单词组成.每个单词仅由小写和大写 ...
- 把指定的字符串翻译成 pig latin。
freecodecamp上的算法题: 把指定的字符串翻译成 pig latin. Pig Latin 把一个英文单词的第一个辅音或辅音丛(consonant cluster)移到词尾,然后加上后缀 & ...
- FCC-学习笔记 Pig Latin
FCC-学习笔记 Pig Latin 1>最近在学习和练习FCC的题目.这个真的比较的好,推荐给大家. 2>中文版的地址:https://www.freecodecamp.cn/;英文版 ...
- 用户输入内容转换成Pig Latin形式。
//(单词的第一个元音字母之前的一道单词后面,以"ay"结尾,英语单词首字母为元音字母或者没有元音字母的以“ay”为后缀.)package toPigLatin; import j ...
- Pig Latin
function translate(str) { //return str; var list = ['a','e','i','o','u']; if(list.indexOf(str[0]) &g ...
- Pig Latin JOIN (inner) 与JOIN (outer)的区别
1.内连接(自然连接): 只有两个表相匹配的行才能在结果集中出现 2.外连接: 包括 (1)左外连接(左边的表不加限制) (2)右外连接(右边的表不加限制) (3)全外连接(左右两表都不加限制) 3. ...
随机推荐
- 这些年,我收集的JavaScript代码(一)
一.取URL中的参数 function getParameterByName(name) { var match = RegExp('[?&]' + name + '=([^&]*)' ...
- js自定义类和对象及继承
1.工厂方式 <script type="text/javascript"> function createObject(name){ var p = new Obje ...
- 第52周二Restful
今天去spring官网发现一个关键词:Restful,以前只在与一个系统对接时用到过这种形式的接口,但印象不深,百度搜索后才感觉自己太out了,这个概念2000年提出,2009年时国内就有很多人推荐使 ...
- 网易云课堂_程序设计入门-C语言_第一周:简单的计算程序_1逆序的三位数
1 逆序的三位数(5分) 题目内容: 程序每次读入一个正三位数,然后输出逆序的数字.注意,当输入的数字含有结尾的0时,输出不应带有前导的0.比如输入700,输出应该是7. 输入格式: 每个测试是一个3 ...
- e = e || window.event用法细节讨论
e = e || window.event是我们在做事件处理时候区分IE和其他浏览器事件对象时常用的写法.但是这行兼容性代码有没有必要出现在所有的事件句柄中呢?标准事件调用方式需要这行代码吗?下边我们 ...
- OceanBase中主备Rootserver如何管理切换
主RootServer会不断给备RootServer发送lease.被RootServer收到该lease后会保存到几个变量中: int ObCheckRunnable::renew_lease(co ...
- poj3267--The Cow Lexicon(dp:字符串组合)
The Cow Lexicon Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 8211 Accepted: 3864 D ...
- UTF-8 BOM编码格式文件对SSI的影响
最近在用SSI(Server Side Includes)加载子模块的时候发现一个奇怪的现象,加载完成后的网页老是CSS有问题,被加载模块渲染后老是有空白部分.下面给出简单的示例. 文件a.html的 ...
- Android之ActionBar学习
关于那个问题:是关于如何生成如下图所示之ActionBar效果: 其实就在官网上就有答案,自己疏忽再加上资料繁多.寻了许久,经过指点.终于找到: To enable split action bar, ...
- asp.net 连接sqlserver数据库
在asp.net中连接sqlserver数据库之前,首先得确保正常安装了sqlserver2008,同时有数据库. 在项目中添加一个类DB,用来专门负责执行对数据库的增删改查.在添加的过程中会弹出下面 ...