HuaWeiJava 上机
1 /*
2 * 第二题,输入字符串长度,字符串,计数m。从前往后计数,当数到m个元素时,m个元素出列,同时将该元素赋值给m,
3 * 然后从下一个数计数循环,直到所有数字都出列,给定的数全部为大于0的数字。输出出队队列。
4 * 例如: 输入:len=4 str="3,1,2,4" m=7
5 * 输出:2,3,1,4
6 */
7 public static String getOutString(int len, String str, int m) {
8 String[] ss = str.split(",");
9 ArrayList<Integer> arrayInt = new ArrayList<Integer>();
10 Stack<Integer> stackInt = new Stack<Integer>();
11 String s = "";
12
13 for(int i = 0; i < ss.length; i++){
14 arrayInt.add(Integer.parseInt(ss[i]));
15 }
16
17 while(arrayInt.size() != 0){
18
19
20 int n = m % arrayInt.size();//第n个数,在arrayInt 中是第 n - 1 个数
21 if(n == 0) {
22 n = arrayInt.size();
23 }
24 m = arrayInt.get(n - 1);
25 //arrayInt.remove(n - 1);
26 //arrayInt 中 第n个数开始
27 for(int i = n - 2; i >= 0; i--){
28 stackInt.push(arrayInt.get(i));
29 }
30 for(int i = arrayInt.size() - 1; i > n -1; i--){
31 stackInt.push(arrayInt.get(i));
32 }
33 System.out.println(arrayInt.remove(n - 1) +"");
34 for(int i = 0; i < arrayInt.size(); i++){
35 arrayInt.set(i, stackInt.pop());
36 }
37 }
38 return s;
39 }
1 import java.util.ArrayList;
2 import java.util.List;
3
4
5 public class HuaWeiTest {
6
7 public static void main(String[] args) {
8 int len=4;
9 String str="3,1,2,4";
10 int m=7;
11 HuaWeiTest hwt = new HuaWeiTest();
12 System.out.println(hwt.getOutString(len, str, m));
13 }
14 public String getOutString(int len, String str, int m) {
15 String ret ="";
16 String[] arr = str.split(",");
17 List<String> ls = new ArrayList<String>();
18 for(int i=0;i<len;i++) {
19 ls.add(arr[i]);
20 }
21 for(int i=0;i<len;i++) {
22 int temp = (m-1)%ls.size();
23 ret += ls.get(temp);
24 m = Integer.parseInt(ls.get(temp))+temp;
25 ls.remove(temp);
26 }
27 return ret;
28 }
29 }
1 package com.huawei.test;
2
3 import java.util.ArrayList;
4 import java.util.List;
5 import java.util.Stack;
6 /**
7 * 第三题,输入一个表达式,没有括号,数字小于0-9之间,输出计算结果,所有的中间结果化为整形。
8 * 例如: 输入:3+8×2/9-2
9 * 输出:2
10 *
11 * @author Administrator
12 *
13 */
14
15 public class HuaWeiTest {
16
17 public static void main(String[] args) {
18
19 System.out.println(getMyRet("3+8/2*2"));
20 }
21
22 public static int getMyRet(String str) {
23 String expression = str.trim();
24 Stack<Integer> operandStack = new Stack<Integer>();
25 Stack<Character> operatorStack = new Stack<Character>();
26
27 for(int i = 0; i < expression.length(); i++){
28 char ch = expression.charAt(i);
29 if(ch == '+' || ch == '-' ){//
30 while(!operatorStack.isEmpty() && (operatorStack.peek() == '+'
31 || operatorStack.peek() == '-'
32 || operatorStack.peek() == '*'
33 || operatorStack.peek() == '/')){
34 processAnOperator(operandStack, operatorStack);
35 }
36 operatorStack.push(ch);
37 }
38 else if (ch == '*' || ch == '/'){
39 while(!operatorStack.isEmpty() && (
40 operatorStack.peek() == '*' || operatorStack.peek() == '/')){
41 processAnOperator(operandStack, operatorStack);
42 }
43 operatorStack.push(ch);
44 }
45 else{
46 operandStack.push(ch - '0');
47 }
48 }
49 while(!operatorStack.isEmpty()){
50 processAnOperator(operandStack, operatorStack);
51 }
52 return operandStack.pop();
53 }
54 public static void processAnOperator(Stack<Integer> operandStack, Stack<Character> operatorStack){
55 char op = operatorStack.pop();
56 int op1 = operandStack.pop();
57 int op2 = operandStack.pop();
58 switch (op) {
59 case '+':
60 operandStack.push(op1 + op2);
61 break;
62 case '-':
63 operandStack.push(op2 - op1);
64 break;
65 case '*':
66 operandStack.push(op1 * op2);
67 break;
68 case '/':
69 operandStack.push(op2 / op1);
70 break;
71 default:
72 break;
73 }
74 }
75 }
HuaWeiJava 上机的更多相关文章
- flhs笔试题-回家上机实践
这是最近参加的一个公司的笔试题,回家上机写了下代码,希望对有需要的小伙伴有用,简单实现字符串和数组在指定位置的插入: package org.flhs; import com.google.commo ...
- Java连接SQLServer2008终极解决办法(亲身上机演练版)
今天我一学妹问我,Java连接SQLServer2008数据库的问题,一直无法连接成功.想起自己刚开始学习的时候,在网上找各种文章,然后实际上机验证操作,花了一两天时间才搞定,一把辛酸泪呀!记得当时是 ...
- 《Java语言程序设计》上机实验
实验一 Java环境演练 [目的] ①安装并配置Java运行开发环境: ②掌握开发Java应用程序的3个步骤:编写源文件.编译源文件和运行应用程序: ③学习同时编译多个Java源文件. [内容 ...
- ztong上机3
二.实验名称:数字图像处理matlab上机 三.实验学时:2学时 四.实验目的:(详细填写) 掌握几何变换 掌握插值 理解配准的概念 五.实验内容 (1)首先自己写一个对图像进行旋转和缩放的复合变换程 ...
- C++ 第一次上机作业
今天完成了C++第一次上机作业,感觉比较简单. 题目: 求2个数或3个正整数中的最大数,用带有默认参数的函数实现. 对3个变量按由小到大顺序排序,要求使用变量的引用. 编写一个程序,用同一个函数名对几 ...
- Twin Prime Conjecture(浙大计算机研究生保研复试上机考试-2011年)
Twin Prime Conjecture Time Limit: 2000/1000 MS (Java/Othe ...
- 代C语言上机实践
这已经是开学第十二周了,个人感觉严老师教的这批学生效果不是很好,有的竟然毫不知道main函数前边的 int是做什么的.只知按照书本上给的样例程序一个字一个字的敲到编译器中,然后点击运行.有错误也不知道 ...
- lingo运筹学上机实验指导
<运筹学上机实验指导>分为两个部分,第一部分12学时,是与运筹学理论课上机同步配套的4个实验(线性规划.灵敏度分析.运输问题与指派问题.最短路问题和背包问题)的Excel.LONGO和LI ...
- JSP脚本元素上机手册
L3 <JSP基础>上机手册 内容回顾 脚本元素<%! %> <%= %> <% %> 注释元素 JSP指令元素 JSP动作元素 上机目标 掌握脚本元素 ...
随机推荐
- IO编程之File类
File类是java.io包下代表与平台无关的文件及目录,程序操作文件和目录都可以通过File类来完成.值得指出的是,不管是文件还是目录都可以通过File类来操作.File能新建.删除.重命名文件和目 ...
- PAT乙级:1066 图像过滤 (15分)
PAT乙级:1066 图像过滤 (15分) 题干 图像过滤是把图像中不重要的像素都染成背景色,使得重要部分被凸显出来.现给定一幅黑白图像,要求你将灰度值位于某指定区间内的所有像素颜色都用一种指定的颜色 ...
- 静态Web服务器(py版)
近来,对http协议进行了研究,闲来无事.自己使用python3写了个静态Web服务器,以下是代码: static_Web_sever.py ''' 思路:首先使用socket创建tcp服务器,照旧绑 ...
- linux下利用JMX监控Tomcat
利用JMX监控Tomcat,就是相当于部署在tomcat上的应用作为服务端,也就是被管理资源的对象.然后通过程序或者jconsole远程连接到该应用上来.远程连接需要服务器端提供ip和port.如果需 ...
- 【动画消消乐 】仿ios、android中常见的一个loading动画 074
前言 Hello!小伙伴! 非常感谢您阅读海轰的文章,倘若文中有错误的地方,欢迎您指出- 自我介绍 ଘ(੭ˊᵕˋ)੭ 昵称:海轰 标签:程序猿|C++选手|学生 简介:因C语言结识编程,随后转入计 ...
- 大数据学习(10)—— Hive进阶
前面提到了Hive的知识点非常零散,我不知道该怎么把这些知识点分类,跟SQL关系没那么大的就放在这一篇吧. Hive Serde 参考Hive Serde Serde是啥 Serde是序列化和反序列化 ...
- 移植TensorFlow到Windows平台
2015年11月,Google宣布开源旗下机器学习工具TensorFlow,引发业界热潮.TensorFlow原生支持*unix系和安卓平台,但并不提供对Windows平台的支持.如果想在Window ...
- 通过比较rgb破解滑动验证码
目标url:信用中国(广东中山)行政处罚 /** * base64转BufferedImage * * @param base64 * @return */ public static Buffere ...
- 阿里内部资料:Android开发核心知识笔记共2100页,58万字,完整版开放下载
作为一个3-5年的Android工程师,我们经常会遇到这些瓶颈: 1.技术视野窄长期在小型软件公司,外包公司工作,技术视野被限制的太厉害 2.薪资提升难初中级Android岗位薪资上升空间有限,基本上 ...
- 大学同学做Java开发比我多5K,八年老Android只会crud该转Java吗?
最近在网上看到这样一个帖子: 做了八年Android开发,感觉这块做着也挺没意思,日常工作就是做一些架构优化,质量数据监控,改一改构建脚本,最主要的是业务负责人没有一个是做客户端的,都是后端的人. 最 ...