1001.比酒量
题干
Description 有一群海盗(不多于20人),在船上比拼酒量。过程如下:打开一瓶酒,所有在场的人平分喝下,有几个人倒下了。再打开一瓶酒平分,又有倒下的,再次重复...... 直到开了第4瓶酒,坐着的已经所剩无几,海盗船长也在其中。当第4瓶酒平分喝下后,大家都倒下了。 等船长醒来,发现海盗船搁浅了。他在航海日志中写到:“......昨天,我正好喝了一瓶.......奉劝大家,开船不喝酒,喝酒别开船......” 请你根据这些信息,推断开始有多少人,每一轮喝下来还剩多少人。 如果有多个可能的答案,请列出所有答案,每个答案占一行。 格式是:人数,人数,... 例如,有一种可能是:20,5,4,2,0 Input 无输入 Output 例如,有一种可能是:20,5,4,2,0 Sample Input 无输入 Sample Output 18,9,3,2,0 15,10,3,2,0 20,5,4,2,0 12,6,4,2,0 SubmitStatistic
代码
package teas1; public class T1 { public static void main(String[] args) { for (int i = 20; i > 6; i--) { for (int j = i-1; j > 3&&i>j; j--) { for (int k = j-1; k > 2&&j>k ; k--) { for (int l = k-1; l > 1&&k>l; l--) { if (j*k*l+i*k*l+i*j*l+i*j*k==i*j*k*l) { System.out.println(i+","+j+","+k+","+l+",0"); } } } } } } }
1002.扑克牌移动
题干
Description 下面代码模拟了一套扑克牌(初始排序A~K,共13张)的操作过程。 操作过程是: 手里拿着这套扑克牌,从前面拿一张放在后面,再从前面拿一张放桌子上,再从前面拿一张放在后面,.... 如此循环操作,直到剩下最后一张牌也放在桌子上。 下面代码的目的就是为了求出最后桌上的牌的顺序。 初始的排列如果是A,2,3...K,则最后桌上的顺序为: [2, 4, 6, 8, 10, Q, A, 5, 9, K, 7, 3, J] import java.util.*; public class A23 { public static List moveCard(List src) { if(src==null) return null; List dst = new Vector(); for(;;) { if(__________________) break; // 填空 src.add(src.remove(0)); dst.add(__________________); // 填空 } return dst; } public static void main(String[] args) { List a = new Vector(); a.addAll(Arrays.asList("A","2","3","4","5","6","7","8","9","10","J","Q","K")); System.out.println(moveCard(a)); } } 请分析代码逻辑,并推测划线处的代码。 Input 将程序完整输入,并将空格处填写完整运行 Output [2,4,6,8,10,Q,A,5,9,K,7,3,J] Sample Input 无 Sample Output [2,4,6,8,10,Q,A,5,9,K,7,3,J]
代码
package teas1; import java.util.*; public class T2 { public static List moveCard(List src) { if(src==null) return null; List dst = new Vector(); for(;;) { if(dst.size()==13) break; // 填空 src.add(src.remove(0)); dst.add(src.remove(0)); // 填空 } return dst; } public static void main(String[] args) { List a = new Vector(); a.addAll(Arrays.asList("A","2","3","4","5","6","7","8","9","10","J","Q","K")); System.out.println(moveCard(a)); } }
1003.括号问题
题干
Description 下面的代码用于判断一个串中的括号是否匹配 所谓匹配是指不同类型的括号必须左右呼应,可以相互包含,但不能交叉 例如: ..(..[..]..).. 是允许的 ..(...[...)....].... 是禁止的 对于 main 方法中的测试用例,应该输出: false true false false import java.util.*; public class A22 { public static boolean isGoodBracket(String s) { Stack<Character> a = new Stack<Character>(); for(int i=0; i<s.length(); i++) { char c = s.charAt(i); if(c==‘(‘) a.push(‘)‘); if(c==‘[‘) a.push(‘]‘); if(c==‘{‘) a.push(‘}‘); if(c==‘)‘ || c==‘]‘ || c==‘}‘) { if(____________________) return false; // 填空 if(a.pop() != c) return false; } } if(___________________) return false; // 填空 return true; } public static void main(String[] args) { System.out.println( isGoodBracket("...(..[.)..].{.(..).}...")); System.out.println( isGoodBracket("...(..[...].(.).){.(..).}...")); System.out.println( isGoodBracket(".....[...].(.).){.(..).}...")); System.out.println( isGoodBracket("...(..[...].(.).){.(..)....")); } } 请分析代码逻辑,并推测划线处的代码。 Input 将程序源码完整输入,并填充下划线中的内容。 Output false true false false Sample Input 无输入 Sample Output false true false false
代码
package teas1; import java.util.*; public class T3 { public static boolean isGoodBracket(String s) { Stack<Character> a = new Stack<Character>(); for(int i=0; i<s.length(); i++) { char c = s.charAt(i); if(c==‘(‘) a.push(‘)‘); if(c==‘[‘) a.push(‘]‘); if(c==‘{‘) a.push(‘}‘); if(c==‘)‘ || c==‘]‘ || c==‘}‘) { if(a.size()==0) return false; // 填空 if(a.pop() != c) return false; } } if(a.size()!=0) return false; // 填空 return true; } public static void main(String[] args) { Scanner scanner=new Scanner(System.in); String string=scanner.nextLine(); System.out.println(isGoodBracket(string)); } }
1004.密码发生器
题干
Description 在对银行账户等重要权限设置密码的时候,我们常常遇到这样的烦恼:如果为了好记用生日吧,容易被破解,不安全;如果设置不好记的密码,又担心自己也会忘记;如果写在纸上,担心纸张被别人发现或弄丢了... 这个程序的任务就是把一串拼音字母转换为6位数字(密码)。我们可以使用任何好记的拼音串(比如名字,王喜明,就写:wangximing)作为输入,程序输出6位数字。 变换的过程如下: 第一步. 把字符串6个一组折叠起来,比如wangximing则变为: wangxi ming 第二步. 把所有垂直在同一个位置的字符的ascii码值相加,得出6个数字,如上面的例子,则得出: 228 202 220 206 120 105 第三步. 再把每个数字“缩位”处理:就是把每个位的数字相加,得出的数字如果不是一位数字,就再缩位,直到变成一位数字为止。例如: 228 => 2+2+8=12 => 1+2=3 上面的数字缩位后变为:344836, 这就是程序最终的输出结果! 要求程序从标准输入接收数据,在标准输出上输出结果。 输入格式为:第一行是一个整数n(<100),表示下边有多少输入行,接下来是n行字符串,就是等待变换的字符串。 输出格式为:n行变换后的6位密码。 Input 例如,输入: 5 zhangfeng wangximing jiujingfazi woaibeijingtiananmen haohaoxuexi Output 则输出: 772243 344836 297332 716652 875843 Sample Input 6 abcdefg kelindun yazhouxiong woainisaibeidexue tiaotiaodalutongluoma xyz Sample Output 289123 849621 748779 137563 848586 345000 Hint 注意: 请仔细调试!您的程序只有能运行出正确结果的时候才有机会得分! 在评卷时使用的输入数据与试卷中给出的实例数据可能是不同的。
代码
package teas1; import java.util.Scanner; public class T4 { /** * @param args */ public static void main(String[] args) { // TODO 自动生成的方法存根 Scanner scanner=new Scanner(System.in); int co=Integer.parseInt(scanner.nextLine()); String[] reString=new String[co]; for (int i = 0; i < co; i++) { reString[i]=getMima(scanner.nextLine()); } //打印值 for (int i = 0; i < reString.length; i++) { System.out.println(reString[i]); } } private static String getMima(String nextLine) { int[] gewei=new int[6]; //分別取每位的值 int conut=0; for (int i = 0; i < nextLine.length(); i++) { gewei[conut]=gewei[conut] + (int)nextLine.charAt(i); conut++; conut=conut>5?0:conut; } //简化成一位数 String reString=""; for (int i = 0; i < gewei.length; i++) { String str=gewei[i]+""; while(gewei[i]>9) { int a=0; for (int j = 0; j < str.length(); j++) { a =a+ Integer.parseInt(str.charAt(j)+""); } gewei[i]=a; str=gewei[i]+""; } reString=reString+gewei[i]+""; } return reString; } }
1005.警察智力训练
题干
Description 匪警请拨110,即使手机欠费也可拨通! 为了保障社会秩序,保护人民群众生命财产安全,警察叔叔需要与罪犯斗智斗勇,因而需要经常性地进行体力训练和智力训练! 某批警察叔叔正在进行智力训练: 1 2 3 4 5 6 7 8 9 = 110; 请看上边的算式,为了使等式成立,需要在数字间填入加号或者减号(可以不填,但不能填入其它符号)。之间没有填入符号的数字组合成一个数,例如:12+34+56+7-8+9 就是一种合格的填法;123+4+5+67-89 是另一个可能的答案。 请你利用计算机的优势,帮助警察叔叔快速找到所有答案。 每个答案占一行。形如: 12+34+56+7-8+9 123+4+5+67-89 ...... Input 无输入 Output 1+2+34+5+67-8+9 1+234-56-78+9 1-2+3+45-6+78-9 12+3+45+67-8-9 12+34+56+7-8+9 12-3+4-5+6+7+89 123+4+5+67-89 123+4-5-6-7-8+9 123-4+5-6-7+8-9 123-4-5+6+7-8-9 Sample Input 无输入 Sample Output 1+2+34+5+67-8+9 1+234-56-78+9 1-2+3+45-6+78-9 12+3+45+67-8-9 12+34+56+7-8+9 12-3+4-5+6+7+89 123+4+5+67-89 123+4-5-6-7-8+9 123-4+5-6-7+8-9 123-4-5+6+7-8-9
代码
package teas1; import java.util.ArrayList; public class T5 { /** * @param args */ public static void main(String[] args) { // TODO 自动生成的方法存根 char[] arr={‘1‘,‘2‘,‘3‘,‘4‘,‘5‘,‘6‘,‘7‘,‘8‘,‘9‘}; char[] fuhao={‘ ‘,‘+‘,‘-‘}; for(char x1:fuhao){ for(char x2:fuhao){ for(char x3:fuhao){ for(char x4:fuhao){ for(char x5:fuhao){ for(char x6:fuhao){ for(char x7:fuhao){ for(char x8:fuhao){ char[] fu={x1,x2,x3,x4,x5,x6,x7,x8}; String string=""; String re=""; ArrayList<String> cha=new ArrayList<>(); for (int i = 0; i < fu.length; i++) { if (!(fu[i]+"").equals(" ")) { string =string+arr[i]+‘,‘; re=re+arr[i]+fu[i]; cha.add(fu[i]+""); }else{ string =string+arr[i]; re =re+arr[i]; } } string+=arr[8]; re+=arr[8]; String[] strArr=string.split(","); int sum=Integer.parseInt(strArr[0]); for (int i = 0; i < strArr.length-1; i++) { if (cha.get(i).equals("+")) { sum+=Integer.parseInt(strArr[i+1]); }else { sum-=Integer.parseInt(strArr[i+1]); } } if(sum==110) System.out.println(re); } } } } } } } } } }
时间: 2024-10-26 06:37:30