繁体   English   中英

无法在 Intellij IDEA 中运行 Java 代码:编译时出错

[英]Unable to run the Java code in Intellij IDEA : error during Compilation

public class RotationsNumbers {
    public int main(String[] args) {
        Solution ans= new Solution();
        int[] arr= {5, 1,2, 3, 4};
        System.out.println(ans.findKRotation(arr , 5));
        return -1;
    }

    class Solution {
        int findKRotation(int arr[], int n) {
            // code here
            int ans= findPivot(arr, 0 , n-1);
            if( ans ==-1) return 0;
            return ans+1;


        }
        int findPivot( int arr[], int start, int end){
            int mid ;
            while(start< end){
                mid= start+ (end- start)/2;
                if (mid < end && arr[mid]> arr[mid+1]){
                    return mid;
                }
                if ( mid > start && arr[mid ]< arr[mid-1]){
                    return mid-1;

                }
                if ( arr[ mid ] < arr[0]){
                    end= mid-1;
                }else{
                    start= mid+1;
                }

            }
            return -1;
        }
    }
}

编辑:尝试使用 static void main too.. 仍然抛出错误 对于上面的代码下面的错误被抛出,我该怎么办?

错误:主方法必须在 class BinarySearch.SortedArray 中返回 void 类型的值,请将主方法定义为:public static void main(String[] args)

进程以退出代码 1 结束

我看到的一些问题

  1. 就像评论中提到的那样,主要应该是public static void main
  2. 主要需要返回语句到 go

下面的代码应该可以工作

 public static void main(String[] args) {
        int[] arr= {5, 1,2, 3, 4};
        System.out.println(findKRotation(arr , 5));
    }

    static int findKRotation(int arr[], int n) {
        // code here
        int ans= findPivot(arr, 0 , n-1);
        if( ans ==-1) return 0;
        return ans+1;


    }
    static int findPivot( int arr[], int start, int end){
        int mid ;
        while(start< end){
            mid= start+ (end- start)/2;
            if (mid < end && arr[mid]> arr[mid+1]){
                return mid;
            }
            if ( mid > start && arr[mid ]< arr[mid-1]){
                return mid-1;

            }
            if ( arr[ mid ] < arr[0]){
                end= mid-1;
            }else{
                start= mid+1;
            }

        }
        return -1;
    }

我认为您使用 class 结构是有原因的,所以除了解决您的问题/疑虑之外,我不会做任何更改:

无法运行Java代码

要运行您的代码,请进行这些更改;

您的解决方案:

public int main(String[] args) {
        Solution ans= new Solution();
        int[] arr= {5, 1,2, 3, 4};
        System.out.println(ans.findKRotation(arr , 5));
        return -1;
    }

变成:

 public static void main(String[] args)
        Solution ans= new Solution();
        int[] arr= {5, 1,2, 3, 4};
        System.out.println(ans.findKRotation(arr , 5));
    }

您的解决方案:

class Solution {

变成:

static class Solution {

通过这些最小的更改,您的代码应该可以运行。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM