zoukankan      html  css  js  c++  java
  • PAT(B) 1010 一元多项式求导(Java)

    题目链接:1010 一元多项式求导
    代码
    /**
     * Score 25
     * Run Time 94ms
     * @author wowpH
     * @version 1.1
     */
    
    import java.util.ArrayList;
    import java.util.List;
    import java.util.Scanner;
    
    public class Main {
    	public static void main(String[] args) {
    		Scanner sc = new Scanner(System.in);
    		String poly = sc.nextLine();	// 输入多项式
    		sc.close();
    
    		// 我不确定有没有多个空格,但是加上肯定错不了
    		poly = poly.trim();	// 去掉首尾空格
    		String[] num = poly.split("\s+");// 分割成数字串数组
    
    		List<Integer> coe, exp;
    		coe = new ArrayList<>();	// 系数简写
    		exp = new ArrayList<>();	// 指数简写
    
    		int c, e;
    		for (int i = 0; i < num.length; i += 2) {
    			e = Integer.parseInt(num[i + 1]);	// 指数
    			if (e > 0) {	// 指数大于0
    				c = Integer.parseInt(num[i]);	// 系数
    				c *= e;	// 求导后的系数
    				e--;	// 求导后的指数
    				coe.add(c);	// 添加系数
    				exp.add(e);	// 添加指数
    			}
    		}
    
    		if (coe.isEmpty()) {	// 零多项式,添加零项
    			coe.add(0);	// 系数为0
    			exp.add(0);	// 指数为0
    		}
    
    		int len = coe.size() - 1;
    		// 输出前面的项
    		for (int i = 0; i < len; i++) {
    			System.out.print(coe.get(i) + " ");
    			System.out.print(exp.get(i) + " ");
    		}
    		// 输出最后一项
    		System.out.print(coe.get(len) + " ");
    		System.out.println(exp.get(len));
    	}
    }
    

    备注:涉及到以下几个知识点

    1. trim()方法,去掉首尾空格
    2. 正则表达式:"\s+",匹配至少一个空格
    3. 分割字符串的split()方法
    4. 列表List
    5. 数组列表ArrayList
    6. 数字串转Integer型的Integer.parseInt()方法
  • 相关阅读:
    数据库插入数据返回当前主键ID值方法
    兼容SQLSERVER、Oracle、MYSQL、SQLITE的超级DBHelper
    C# listview 单击列头实现排序 <二>
    C# ListView点击列头进行排序
    MessageBox.Show()的各种用法
    QT 删除文件指定目录
    hihoCoder 1015 KMP算法
    hiho一下 第五十周 (求欧拉路径)
    hdu
    hiho一下 第四十九周 欧拉路
  • 原文地址:https://www.cnblogs.com/wowpH/p/11060787.html
Copyright © 2011-2022 走看看