java list.get(i) 效率_Java运行效率问题?一个例子

这是牛客网上的一道题目(不看应该也没关系)Reversing Linked List

第一个代码,可以通过测试,第二个代码运行超时,两个代码非常相似,我分析不出第二个代码哪一部分出了问题。

盼慕友回复。下面是代码:

通过测试的代码:import java.util.ArrayList;

import java.util.HashMap;

import java.util.Scanner;

//模拟链表每K位反转,因为输入可能有无效节点,所以先要把所有节点存起来

//使用hashmap存入节点,然后根据首地址一个个读取节点,存入数组,对数组每k位进行反转

public class Main {

public static void main(String[] args) {

Scanner sc=new Scanner(System.in);

int first=sc.nextInt();

int n=sc.nextInt();

int k=sc.nextInt();

HashMap map =new HashMap();

ArrayList list=new ArrayList();

while(n!=0){//存入数据

int adr=sc.nextInt();

int val=sc.nextInt();

int next=sc.nextInt();

map.put(adr, new Node(adr,val,next));

n--;

}

sc.close();

while(first!=-1){//有序取出元素,过滤掉无用节点

Node node=map.get(first);

list.add(node);

first=node.next;

}

//给每K位排序,排序后第i个节点的Next并没有保存下一个节点信息,但是list已经有序

//直接输出i+1的address即可;

for(int i=k;i<=list.size();i+=k){

int l=i-k;

int r=i-1;

while(l

Node t=list.get(l);

list.set(l,list.get(r));

list.set(r, t);

l++;

r--;

}

}

//输出结果,地址小于5位前面补0

for(int i = 0; i

String str = ""+list.get(i).address;

String str2 = ""+list.get(i+1).address;

while(str.length() 

str = "0"+str;

while(str2.length() 

str2 = "0"+str2;

System.out.println(str + " " + list.get(i).value + " " + str2);

}

String str = ""+list.get(list.size()-1).address;

while(str.length() 

str = "0"+str;

System.out.println(str + " " + list.get(list.size()-1).value + " -1");

}

}

class Node{

int address;

int value;

int next;

public Node(int adr,int v,int ne){

address=adr;

value=v;

next=ne;

}

}

运行超时的代码:import java.util.ArrayList;

import java.util.HashMap;

import java.util.Scanner;

public class Main {

public static void main(String[] args) {

Scanner in = new Scanner(System.in);

int firstAddr = in.nextInt();

int n = in.nextInt();

int k = in.nextInt();

//输入数据,存放在HashMap中。

HashMap map = new HashMap();

ArrayList ls = new ArrayList();

for(int i = 0; i 

int addr = in.nextInt();

int data = in.nextInt();

int next = in.nextInt();

map.put(addr, new Node(addr, data, next));

}

in.close();

//将属于链表的节点元素放入ArrayList中。

while(firstAddr != -1) {

Node node = map.get(firstAddr);

ls.add(node);

firstAddr = node.next;

}

map.clear();

//给每K个元素排序

for(int i = k; i <= ls.size(); i += k) {

int begin = i - k;

int end = i - 1;

while(begin 

Node tmp = ls.get(begin);

ls.set(begin++, ls.get(end));

ls.set(end--, tmp);

}

}

//输出

for(int i = 0; i 

System.out.printf("%05d %d %05d\n", ls.get(i).addr, ls.get(i).data, ls.get(i + 1).addr);

System.out.printf("%05d %d %d\n", ls.get(ls.size() - 1).addr, ls.get(ls.size() - 1).data, -1);

}

}

class Node {

//    String addr;    //使用String类,运行效率低?醉了o(╯□╰)o。

int addr;

int data;

int next;

//    String next;

public Node(int addr, int data, int next) {

this.addr = addr;

this.data = data;

this.next = next;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Connection con = null ; PreparedStatement pstmt = null; try { con = this.getSqlMapClientTemplate().getDataSource().getConnection(); con.setAutoCommit(false); pstmt = con.prepareStatement("INSERT INTO AMS_BUSINESS_TODO(BUSINESS_TODO_ID, USER_ID, TABLE_ID, BUSINESS_LINK_ID, BUSINESS_LINK_SOURCE_ID, " + "ENTRY_ID, ENTRY_TITLE, TODO_BATCH_ID, TODO_STATE, HAPPEN_DATE, FILING_MODE, VALID_FLAG,TODO_SUBMIT_USER_ID)" //新增组织机构ID,角色ID以及提交人ID +"values(?,?,?,?,?,?,?,?,?,?,?,?,?)"); Long id = Long.valueOf(SequenceUtil.get_id(KeyConstant.AMS_BUSINESS_TODO_ID, list.size())); for (int i = 0; i < list.size(); i++) { list.get(i).setBusiness_todo_id(id + i); pstmt.setLong(1, id + i); pstmt.setLong(2, list.get(i).getUser_id()); pstmt.setLong(3, list.get(i).getTable_id()); pstmt.setLong(4, list.get(i).getBusiness_link_id()); pstmt.setLong(5, list.get(i).getBusiness_link_source_id()); pstmt.setLong(6, list.get(i).getEntry_id()); pstmt.setString(7, list.get(i).getEntry_title()); pstmt.setLong(8, list.get(i).getTodo_batch_id()); pstmt.setInt(9, list.get(i).getTodo_state()); pstmt.setTimestamp(10, list.get(i).getHappen_date()); pstmt.setInt(11, list.get(i).getFiling_mode()); pstmt.setInt(12, list.get(i).getValid_flag()); pstmt.setLong(13, list.get(i).getTodo_submit_user_id()); pstmt.addBatch(); } pstmt.executeBatch(); con.commit(); r.setMessage("导入完成"); r.setResult(id); r.setState(true); return r; } catch (SQLException e) { e.printStackTrace(); return R.falseState("导入失败"); }finally{ if(pstmt != null){ try { pstmt.close(); } catch (SQLException e) { e.printStackTrace(); } } if(con != null){ try { con.close(); } catch (SQLException e) { e.printStackTrace(); } } }如何给上述代码中的insert参数里面添加null值
06-02

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值