求助,这个问题的更好的算法(空间时间复杂度尽量低).

lookahead99 2005-04-20 11:23:36
就是给一个数组.找到这个数组中的某个特定的值,然后把这个值转移到第一个.
本来没什么问题.但是人要求尽量节省空间和时间..
偶对这个没研究,只好求助大虾门了.

这个市偶写的..

class Fun{

public void change(int[]arr,int a){//find the index

for (int i = 0; i<arr.length;i++){
if (arr[i]==a){
changeFun(arr,i);
}
}
}

public void changeFun(int[]arr,int a){//change it
int temp = arr[a];


for (int j = a; j > 0; j--){
arr[j] = arr[j-1];

}


arr[0] = temp;

}

public static void main(String[] args){

int [] a = {1,2,3,5,6,3,7,8,3,4};//3331256784
Fun f = new Fun();
f.change(a,3);
for (int i = 0; i<a.length; i++){
System.out.print(a[i]);
System.out.print("**");

}


}

}
...全文
93 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
cuilichen 2005-04-20
  • 打赏
  • 举报
回复
楼上的注意了:
楼主说的是移动,不是交换。呵呵。
建议使用链表。
链表的具体的实现,可以搜索一下java的数据结构。

如果非要使用数组的话,楼主的方法已经不错了,
我不知道效率更高的其他方法。
chinajava 2005-04-20
  • 打赏
  • 举报
回复
class Fun{

public void change(int[]arr,int a){//find the index

for (int i = 0; i<arr.length;i++){
if (arr[i]==a){
int tem=arr[0];
arr[0]=a;
arr[i]=tem;
break;
}
}
}


public static void main(String[] args){

int [] a = {1,2,3,5,6,3,7,8,3,4};//3331256784
Fun f = new Fun();
f.change(a,3);
for (int i = 0; i<a.length; i++){
System.out.print(a[i]);
System.out.print("**");

}


}

}
dj0517 2005-04-20
  • 打赏
  • 举报
回复
关注+学习
随风来去 2005-04-20
  • 打赏
  • 举报
回复
使用链表比较好
yulin001122 2005-04-20
  • 打赏
  • 举报
回复
up

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧