题目:一元多项式求导 (25 分)
设计函数求一元多项式的导数。(注:xn(n为整数)的一阶导数为nxn−1。)
输入格式:
以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过 1000 的整数)。数字间以空格分隔。
输出格式:
以与输入相同的格式输出导数多项式非零项的系数和指数。数字间以空格分隔,但结尾不能有多余空格。注意“零多项式”的指数和系数都是 0,但是表示为 0 0。
输入样例:
3 4 -5 2 6 1 -2 0
输出样例:
12 3 -10 1 6 0
这个题目,怎么说呢,感觉一直用字符串切割终于受到了制裁。不知道为什么,明明自己用了好多数字都没有问题,测试用例也没有问题,但是就是过不了。最后就是照着大佬的代码打出来的,其实思路上倒是没有什么问题,首先明确输出的是导数多项式非零项,就是说遇上系数为0就不输出,然后就是零多项式要输出"0 0"。像这样不能用字符串切割的情况其实没有这么遇到过,主要问题在于难以判断边界,今天也是学到了吧,不然真的怀疑到考试的时候会受影响。附上代码:
import java.util.Scanner;
public class Pro_1010 {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int one_letter[]=new int[2];
int isHaveOutput = 0;
while (in.hasNext()) {
one_letter[0] = in.nextInt();
one_letter[1] = in.nextInt();
if (one_letter[0] * one_letter[1] != 0) {
//当出现零时做判断,是零方程式还是常数项的阶数零
if (isHaveOutput!=0) {
System.out.print(" ");
} else {
isHaveOutput = 1;
}
System.out.print(one_letter[0] * one_letter[1] + " " + (one_letter[1] - 1));
}
}
in.close();
if (isHaveOutput==0) {
System.out.print("0 0");
}
}
}