设计函数求一元多项式的导数。(注:xn(n为整数)的一阶导数为nxn−1。)
输入格式:
以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过 1000 的整数)。数字间以空格分隔。
输出格式:
以与输入相同的格式输出导数多项式非零项的系数和指数。数字间以空格分隔,但结尾不能有多余空格。注意“零多项式”的指数和系数都是 0,但是表示为 0 0。(这句话的意思其实是 0 的n次方求导后对应的输出为 0 0,所以我加粗了)
输入样例:
3 4 -5 2 6 1 -2 0
输出样例:
12 3 -10 1 6 0
解题思路:
这道题刚开始我研究了很久,都没搞懂他输入输出是啥意思,可能有很多小伙伴和我一样,好吧,来分析一下题。
输入的意思:3的4次方,-5的2次方,6的1次方,-2的0次方(即常数1)
输出的意思(系数、指数): (12 3 ) (-10 1) (6 0) (常数求导为0,所以没有输出)
括号是没有的,是我为了方便大家搞懂题。
好了,开始解题。
以每2个数字输入为1组(假定第一个数为M,第二个数为N)
1.特殊情况:如果第1个数等于0,则输出 0 0;
2.如果第一个数不为0 ,第二个数大于或者小于0,则系数为:M*N,指数为:N-1;
3.如果第一个数不为0 ,第二个数等于0 ,这说明这个数是常数,则不用输出
完毕,代码来了:
- 题不难,但有个坑就是输入的字符串中间的空格不止一个,得用split("\s+")
- "\s+"是正则表达式形式,\转义成\ ,\与s组成\s,表示空格,+表示至少1个空格。
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);// 接收输入
String[] num = in.nextLine().trim().split("\\s+");
in.close();
// 将输入数字去掉头尾空格并以空格为界保存到字符串数组
String out = "";// 最后要输出的字符串
for (int i = 0; i < num.length; i += 2) {
int xiShu = Integer.parseInt(num[i]);// 输入项的系数
int zhiShu = Integer.parseInt(num[i + 1]);// 输入项的指数
int xiShuD = xiShu * zhiShu;// 导数项的系数
int zhiShuD = zhiShu - 1;// 导数项的指数
if (i == 0 && zhiShu == 0)// “零多项式”的指数和系数都是0,但是表示为“0 0”。
{
out = "0 0";
break;
}
if (xiShuD == 0)// 如果是导数项为0,不输出
continue;
out = out + xiShuD + " " + zhiShuD + " ";// 将要输出的字符串保存起来
}
System.out.print(out.trim());// 去除字符串最后的空格并输出。
}
}