欧几里得算法

问题描述 投票:0回答:1

我需要在我的Android程序中使用欧几里德算法。这是我的主要活动:

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;

public class MainActivity extends Activity {
TextView answer;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    answer = (TextView) findViewById(R.id.textView1);
    
     Button proceed = (Button) findViewById(R.id.button1);
     proceed.setOnClickListener(new OnClickListener() {

            public void onClick(View v) {
                int ans = Euclid.gcd(6, 9);
                answer.setText(ans);
            }
        });
       }

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
}


}

我希望我的程序做的事情是,当我单击按钮时给我最大公除法(GCD)。我正在尝试用这部分代码来做到这一点:

public void onClick(View v) {
int ans = Euclid.gcd(6, 9);
answer.setText(ans);
}

这是我的欧几里得课程:

public class Euclid {

// recursive implementation
public static int gcd(int p, int q) {
    if (q == 0) return p;
    else return gcd(q, p % q);
}

// non-recursive implementation
public static int gcd2(int p, int q) {
    while (q != 0) {
        int temp = q;
        q = p % q;
        p = temp;
    }
    return p;
}

public static void main(String[] args) {
    int p = Integer.parseInt(args[0]);
    int q = Integer.parseInt(args[1]);
    int d  = gcd(p, q);
    int d2 = gcd2(p, q);
    System.out.println("gcd(" + p + ", " + q + ") = " + d);
    System.out.println("gcd(" + p + ", " + q + ") = " + d2);
}
}

问题是,当我单击按钮时,我的应用程序崩溃了。那么问题出在哪里以及如何解决呢?我知道 onClick 部分无效。

java android algorithm division greatest-common-divisor
1个回答
2
投票

TextView.setText(int)
的整数参数是资源ID,而不是要显示的文字整数。相反,使用类似的东西

answer.setText(Integer.toString(ans));

在 TextView 中显示整数。

© www.soinside.com 2019 - 2024. All rights reserved.