zoukankan      html  css  js  c++  java
  • 算法训练 C*++ Calculations

      算法训练 C*++ Calculations  
    时间限制:2.0s   内存限制:64.0MB
        
    问题描述
      C*++语言和C++语言非常相似,然而C*++的程序有时会出现意想不到的结果。比如像这样的算术表达式:
      表达式=基本式 / 表达式+基本式 / 表达式-基本式
      基本式=增量 / 系数*增量
      增量=a++ / ++a
      系数=0/1/2/……/1000
      如“5*a++-3*++a+a++”是合法的C*++表达式。
      计算这样的表达式的值的方法:首先是每个基本式进行计算,然后按照正常的算术运算法则计算。如果一个基本式包含“a++”,则先进行乘法运算再使变量a权值+1;如果一个基本式包含“++a”,则先使变量a权值+1再进行乘法运算。
      然而基本式可以按任意顺序计算,这就是为什么计算结果是完全无法预料的。
      你的任务就是去找到最大的可能结果。

      第一行,一个整数n,表示变量a的初始值。
      第二行,一个合法的C*++表达式。

      共一行,一个整数ans,表示最大可能结果。
    输入格式
      input 1:
      1
      5*a++-3*++a+a++
      input 2:
      3
      a+++++a
    输出格式
      output 1:
      11
      output 2:
      8
    数据规模和约定
      对于20%的数据,表达式长度<=20。
      另有20%的数据,满足n>=0。
      对于100%的数据,-1000<=n<=1000,表达式长度<=10000。
      注意表达式开头可能有负号!
     
     1 #include <stdio.h>
     2 #include <string.h>
     3 #define MAXSIZE 10011
     4 /*大致思想为将每个++a或者a++的系数提取出来进行排序,之后按照
     5 a从初始值开始递增的形式进行相加,需要注意的是++a的情况,需要提前额外加一次*/
     6 int n, ans, k, coe, len, outcome, c[MAXSIZE];
     7 char e[MAXSIZE], s[MAXSIZE];
     8 
     9 void sort(int x)
    10 {
    11     int i, j, t;
    12 
    13     for(i = 1; i < x; i ++){
    14         for(j = i+1; j > 1; j--){
    15 
    16             if(c[j] < c[j-1]){
    17                 t = c[j-1];
    18                 c[j-1] = c[j];
    19                 c[j] = t;
    20             }else{
    21                 break;
    22             }
    23         }
    24     }
    25 }
    26 
    27 int calculate()
    28 {
    29     int i, j;
    30 
    31     k = outcome = 0;
    32     strcpy(s, e);
    33     len = strlen(s);
    34 
    35     if(s[0] != '-'){
    36 
    37         for(i = len + 1; i > 0; i --){
    38             s[i] = s[i-1];
    39         }
    40 
    41         s[0] = '+';
    42         len ++;
    43     }
    44 
    45     for(i = 0; i < len; i += 3){
    46 
    47         if(s[i] == '+'){
    48             coe = 1;
    49         }else{
    50             coe = -1;
    51         }
    52 
    53         i ++;
    54         j = 0;
    55         while('0' <= s[i] && s[i] <= '9'){
    56             j *= 10;
    57             j += s[i++] - '0';
    58         }
    59 
    60         if(s[i] == '*'){
    61             i ++;
    62         }else{
    63             j = 1;
    64         }
    65 
    66         coe *= j;
    67         c[++k] = coe;
    68         outcome += (n-(s[i] == 'a')) * coe;
    69     }
    70 
    71     sort(k);
    72     for(i = 1; i <= k; i ++){
    73         outcome += i * c[i];
    74     }
    75 
    76     return outcome;
    77 }
    78 
    79 int main()
    80 {
    81     scanf("%d %s", &n, e);
    82 
    83     ans = calculate();
    84 
    85     printf("%d
    ", ans);
    86 
    87     return 0;
    88 }
  • 相关阅读:
    c++
    zjoi 力
    poj 3415
    [SDOI2014]旅行
    模板测试
    [WC2006]水管局长
    HDU5730
    [NOI2014]魔法森林
    [NOI2012]骑行川藏(未完成)
    [NOI2012]随机数生成器
  • 原文地址:https://www.cnblogs.com/CZT-TS/p/8448978.html
Copyright © 2011-2022 走看看