代码:
public class Sorting0{
public int[] sort(int[] num){
for(int i=0;i<num.length;i++){
for(int j=0;j<num.length-i-1;j++){
if(num[j]<num[j+1]){
int n=0;
n=num[j];
num[j]=num[j+1];
num[j+1]=n;
}
}
}
return num;
}
public static void main(String[] args){
Scanner input=new Scanner(System.in);
int k=input.nextInt();
Sorting0 s=new Sorting0();
int[] num=new int[100];
for(int i=0;i<k;i++){
num[i]=input.nextInt();
}
s.sort(num);
while(input.hasNext()){
if(input.nextInt()>num[k-1]){
if(input.nextInt()>num[k-2]){
num[k-1]=num[k-2];
}
else{
num[k-1]=input.nextInt();
}
}
}
System.out.println(num[k-1]);
}
}
不知道为什么不对,求助.
排序没有问题(当然内侧循环没必要对已经排序的部分再遍历了)。int k=input.nextInt();
这里输入的k代表的应该是数组的大小,而不是第k大的k,建议将k重命名为n
`while(input.hasNext()){
if(input.nextInt()>num[k-1]){
if(input.nextInt()>num[k-2]){
num[k-1]=num[k-2];`
这里不对,你怎么又去读取输入呢?你这里需要输入的是你指定的k,然后直接返回或者输出num[n-k]
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。