问题描述

令二元函数f(x,y)=ax+by,a和b为整数,求一个表达式S的值。

  只有满足以下要求的表达式才是合法的:

  1.任意整数x是一个合法的表达式;

  2.如果A和B都是合法的表达式,则f(A,B)也是一个合法的表达式。

输入格式

第一行两个数a和b;

  第二行一个字符串S表示要求的表达式。

输出格式

一行一个数表示表达式S的值。

样例输入

1 2

f(1,f(1,-1))

样例输出

-1

数据规模和约定

S的长度不超过50,运算过程中所有变量不会超出int的范围。

PS:

测试数据搞心态???

  1. package 第十次模拟;
  2. import java.util.Scanner;
  3. import java.util.Stack;
  4. public class 二元函数 {
  5. public static void main(String[] args) {
  6. Stack<Integer> num = new Stack<Integer>();
  7. Scanner sc = new Scanner(System.in);
  8. int a = sc.nextInt();
  9. int b = sc.nextInt();
  10. sc.nextLine(); //用于消除第一个回车
  11. String str = sc.nextLine(); //输入字符串
  12. try {
  13. if(Integer.valueOf(str)>0){
  14. System.out.println(str);
  15. return;
  16. }
  17. } catch (Exception e) {
  18. // TODO: handle exception
  19. }
  20. char[] s = str.toCharArray(); //转换为数组操作
  21. for(int i =0 ;i < s.length;i++){
  22. if(s[i] == '-'){ //如果是 为负数
  23. i++ ; //使索引指向负号下面一个元素
  24. i = getNumber(num, s, i,false);
  25. }else if(Character.isDigit(s[i])){ //
  26. i = getNumber(num, s, i,true);
  27. }
  28. if(s[i] == ')'){
  29. int x = num.pop();
  30. int y = num.pop();
  31. //x应该是在算式中是靠后的元素,所以应该互换位置
  32. num.push(count(a,b,y,x)) ;
  33. }
  34. }
  35. System.out.println(num.pop());
  36. }
  37. //计算一个f()的值 。
  38. public static int count(int a , int b , int x , int y){
  39. return a*x+b*y;
  40. }
  41. //获取一个完整的数值。 返回一个索引
  42. public static int getNumber(Stack<Integer> stack,char[] s ,int i,Boolean pos){
  43. int number = 0 ;
  44. for(;s[i] != ','&&s[i]!=')';i++){
  45. number = number * 10 +s[i]-'0';
  46. }
  47. if(!pos){
  48. stack.push(-number); //对有符号的进行取反处理
  49. } else
  50. //入栈操作
  51. stack.push(number);
  52. if(s[i] == ' '){
  53. return i ;
  54. }
  55. return i ;
  56. }
  57. }

Java实现 蓝桥杯VIP 算法训练 二元函数的更多相关文章

  1. Java实现蓝桥杯VIP算法训练 二元函数

    试题 算法训练 二元函数 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 令二元函数f(x,y)=ax+by,a和b为整数,求一个表达式S的值. 只有满足以下要求的表达式才是合法的: ...

  2. Java实现 蓝桥杯VIP 算法训练 sign函数

    试题 算法训练 sign函数 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 给定实数x,输出sign(x)的值. sign(x)是符号函数,如果x>0,则返回1:如果x=0, ...

  3. Java实现蓝桥杯VIP 算法训练 sign函数

    问题描述 给定实数x,输出sign(x)的值. sign(x)是符号函数,如果x>0,则返回1:如果x=0,则返回0:如果x<0,则返回-1. 输入格式 一行一个实数x. 输出格式 一行一 ...

  4. Java实现蓝桥杯VIP 算法训练 找公倍数

    问题描述 这里写问题描述. 打印出1-1000所有11和17的公倍数. 样例输入 一个满足题目要求的输入范例. 样例输出 与上面的样例输入对应的输出. 这道题其实没有什么可写的,但是为了让读者更方便的 ...

  5. Java实现 蓝桥杯VIP 算法训练 连通分块(并查集)

    试题 算法训练 连通分块 资源限制 时间限制:200ms 内存限制:8.0MB 问题描述 连通分块 输入格式 输入的第一行包含两个整数n, m n代表图中的点的个数,m代表边的个数 接下来m行,每行2 ...

  6. Java实现 蓝桥杯VIP 算法训练 无权最长链

    试题 算法训练 无权最长链 问题描述 给定一个n节点m边的无圈且连通的图,求直径 输入格式 第一行两个数字n,m 接下来m行每行两个数字x,y,代表x,y之间有一条边 输出格式 要求用户的输出满足的格 ...

  7. Java实现 蓝桥杯VIP 算法训练 星际交流

    算法训练 星际交流 时间限制:1.0s 内存限制:256.0MB 问题描述 人类终于登上了火星的土地并且见到了神秘的火星人.人类和火星人都无法理解对方的语言,但是我们的科学家发明了一种用数字交流的方法 ...

  8. Java实现 蓝桥杯VIP 算法训练 Car的旅行路线

    大家可以看一下这个,蓝桥杯官网的这道题是有问题的 Car的旅行路线 算法训练 Car的旅行路线 时间限制:1.0s 内存限制:256.0MB 提交此题 锦囊1 锦囊2 查看参考代码 问题描述 又到暑假 ...

  9. Java实现 蓝桥杯VIP 算法训练 最大质因数(暴力)

    试题 算法训练 最大质因数 问题描述 给出N个数字,求出有最大的最大质因数的那个数 输入格式 第一行:一个整数N. 接下来的N行,每行一个整数A_i,表示给出的那N个数字. 输出格式 第一行:一个整数 ...

随机推荐

  1. Codeforces Round #635C Linova and Kingdom 思维

    Linova and Kingdom 题意 现在有一颗n个节点的树,每个节点是一个城市,现在要选出k个城市作为工业城市,其他城市作为旅游城市,现在每个工业城市要派出一名特使前往根节点,每个特使的幸福度 ...

  2. python学习第七天--文件系统常用模块os,os.path,pickle

    模块是一个可用代码段的打包,后缀名为py,可被别的程序引入#使用import OS模块:operting system操作系统#import os os.chdir(path) 改变当前工作目录 os ...

  3. 多线程测试时的辅助类--CountDownLatch

    多线程时,很多时候由于mian线程与多线程结束时间不可控,造成无法测试 辅助测试类---CountDownLatch 我看的视频教程匿名内部类无法使用外部的变量,所以CountDownLatch定义为 ...

  4. C# 数据操作系列 - 5. EF Core 入门

    0.前言 上一章简单介绍了一下ORM框架,并手写了一个类似ORM的工具类.这一章将介绍一个在C#世界里大名鼎鼎的ORM框架--Entity Framework的Core版. Entity Framew ...

  5. python爬虫-直播吧

    概述 这是一个我很喜欢的小网站,想了解这个网站先从爬虫开始,爬取直播吧所有的栏目及内容,再存入数据库.先写个简单点的,后期再不断的优化下. 准备阶段 直播吧网址https://www.zhibo8.c ...

  6. security安全框架,用户登录安全认证与退出

    一.创建用户表及实体类 二.编写security配置文件 <?xml version="1.0" encoding="UTF-8"?><bea ...

  7. js判断数组(数组对象)中是否存在指定的值,如果存在就删除

    数组中是否存在指定值,存在就删除 var str = ["a", "b", "c"]; var index = str.indexOf(&q ...

  8. Spring Junit--第一个测试

    配置成功后,需要启动测试用例! package com.cml.controller; import javax.annotation.Resource; import org.junit.Test; ...

  9. 8、HTTPS证书Actions无法导出问题

    前言 在点Actions时候出现Export Failed:The root certificate could not be located.最近有很多小伙伴在fiddler导出证书的时候,遇到无法 ...

  10. JSP中System.out.println()与out.println()区别

    1.out.println()输出到客户端. 在out.println()中,out是response的实例,是以response为对象进行流输出的,即将内容输出到客户端. 如果在JSP页面中使用Sy ...