zoukankan      html  css  js  c++  java
  • UVA215-Spreadsheet Calculator(模拟+拓扑排序)

    Problem UVA215-Spreadsheet Calculator

    Accept:401  Submit:2013

    Time Limit: 3000 mSec

    Problem Description

    A spreadsheet is a rectangular array of cells. Cells contain data or expressions that can be evaluated to obtain data. A “simple” spreadsheet is one in which data are integers and expressions are mixed sums and differences of integers and cell references. For any expression, if each cell that is referenced contains an integer, then the expression can be replaced by the integer to which the expression evaluates. You are to write a program which evaluates simple spreadsheets.

     Input

    Input consists of a sequence of simple spreadsheets. Each spreadsheet begins with a line specifying the number of rows and the number of columns. No spreadsheet contains more than 20 rows or 10 columns. Rows are labeled by capital letters A through T. Columns are labeled by decimal digits 0 through 9. Therefore, the cell in the first row and first column is referenced as A0; the cell in the twentieth row and fifth column is referenced as T4.
    Following the specification of the number of rows and columns is one line of data for each cell, presented in row-major order. (That is, all cells for the first row come first, followed by all cells for the second row, etc.) Each cell initially contains a signed integer value or an expression involving unsigned integer constants, cell references, and the operators + (addition) and - (subtraction). If a cell initially contains a signed integer, the corresponding input line will begin with an optional minus sign followed by one or more decimal digits. If a cell initially contains an expression, its input line will contain one or more cell references or unsigned integer constants separated from each other by + and - signs. Such a line must begin with a cell reference. No expression contains more than 75 characters. No line of input contains leading blanks. No expression contains any embedded blanks. However, any line may contain trailing blanks.
    The end of the sequence of spreadsheets is marked by a line specifying 0 rows and 0 columns.

     Output

    For each spreadsheet in the input, you are to determine the value of each expression and display the resulting spreadsheet as a rectangular array of numbers with the rows and columns appropriately labeled. In each display, all numbers for a column must appear right-justified and aligned with the column label.
    Operators are evaluated left to right in each expression; values in cells are always less than 10000 in absolute value. Since expressions may reference cells that themselves contain expressions, the order in which cells are evaluated is dependent on the expressions themselves.
    If one or more cells in a spreadsheet contain expressions with circular references, then the output for that spreadsheet should contain only a list of the unevaluated cells in row-major order, one per line, with each line containing the cell label, a colon, a blank, and the cell’s original expression.
    A blank line should appear following the output for each spreadsheet.

     Sample Input

    2 2
    A1+B1
    5
    3
    B0-A1
    3 2
    A0
    5
    C1
    7
    A1+B1
    B0+A1
    0 0
     
     

     Sample Ouput

          0     1
    A     3     5
    B     3    -2
    A0: A0
    B0: C1
    C1: B0+A1
     
    题解:一道模拟题,我一开始没理解题意,WA了两发,主要是没有考虑可以计算的数字表达式,考虑了之后就没有太大问题了。
    这个题的递归函数框架其实是按照拓扑排序来写的,vis数组三种状态0,1,-1,分别表示未访问,正在访问,已访问。这样就可以轻松找环(dfs过程中遇到vis为-1的点就意味着找到了环)。
    把环标记一下可以大大剪枝。
     
      1 #include <iostream>
      2 #include <cstring>
      3 #include <cstdlib>
      4 #include <cstdio>
      5 using namespace std;
      6 
      7 const int Row = 22,Cloumn = 12;
      8 const int maxl = 80;
      9 int vis[Row][Cloumn];
     10 bool is_circle[Row][Cloumn];
     11 int n,m;
     12 
     13 struct Point{
     14     bool is_num;
     15     int num;
     16     char ss[80];
     17     Point(bool is_num = false,int num = 0) :
     18         is_num(is_num),num(num) {}
     19 };
     20 Point gra[Row][Cloumn];
     21 
     22 bool dfs(int x,int y){
     23     if(is_circle[x][y]) return false;
     24     if(vis[x][y] == -1){
     25         gra[x][y].is_num = false;
     26         is_circle[x][y] = true;
     27         return false;
     28     }
     29     if(vis[x][y] == 1) return true;
     30     vis[x][y] = -1;
     31     int ans = 0;
     32     char *p = &gra[x][y].ss[0];
     33     int flag = 1;
     34     //bool IsNum = true;
     35     for(int i = 0;i < strlen(p);){
     36         if(p[i] == '+'){
     37             i++;
     38             flag = 1;
     39             continue;
     40         }
     41         else if(p[i] == '-'){
     42             i++;
     43             flag = -1;
     44             continue;
     45         }
     46         if(isdigit(p[i])){
     47             int temp;
     48             sscanf(p+i,"%d",&temp);
     49             ans += temp*flag;
     50             while(isdigit(p[i])) i++;
     51         }
     52         else{
     53             //IsNum = false;
     54             int r = p[i]-'A',c = p[i+1]-'0';
     55             i += 2;
     56             if(gra[r][c].is_num) ans += flag*gra[r][c].num;
     57             else{
     58                 if(dfs(r,c)){
     59                     ans += flag*gra[r][c].num;
     60                 }
     61                 else{
     62                     gra[x][y].is_num = false;
     63                     is_circle[x][y] = true;
     64                     vis[x][y] = 1;
     65                     return false;
     66                 }
     67             }
     68         }
     69     }
     70     gra[x][y].is_num = true;
     71     gra[x][y].num = ans;
     72     vis[x][y] = 1;
     73     return true;
     74 }
     75 
     76 void output(){
     77     printf(" ");
     78     for(int i = 0;i < m;i++){
     79         printf("%6d",i);
     80     }
     81     printf("
    ");
     82     for(int i = 0;i < n;i++){
     83         printf("%c",i+'A');
     84         for(int j = 0;j < m;j++){
     85             printf("%6d",gra[i][j].num);
     86         }
     87         printf("
    ");
     88     }
     89 }
     90 
     91 int main()
     92 {
     93     //freopen("input.txt","r",stdin);
     94     //freopen("output.txt","w",stdout);
     95     while(~scanf("%d%d",&n,&m) && (n||m)){
     96         char str[100];
     97         memset(vis,0,sizeof(vis));
     98         memset(is_circle,false,sizeof(is_circle));
     99         for(int i = 0;i < n;i++){
    100             for(int j = 0;j < m;j++){
    101                 scanf("%s",str);
    102                 gra[i][j].is_num = false;
    103                 strncpy(gra[i][j].ss,str,sizeof(str));
    104             }
    105         }
    106         for(int i = 0;i < n;i++){
    107             for(int j = 0;j < m;j++){
    108                 if(gra[i][j].is_num) continue;
    109                 dfs(i,j);
    110             }
    111         }
    112         bool ok = true;
    113         for(int i = 0;i < n;i++){
    114             int j;
    115             for(j = 0;j < m;j++){
    116                 if(is_circle[i][j]){
    117                     ok = false;
    118                     break;
    119                 }
    120             }
    121             if(j != m) break;
    122         }
    123         if(ok){
    124             output();
    125         }
    126         else{
    127             for(int i = 0;i < n;i++){
    128                 for(int j = 0;j < m;j++){
    129                     if(is_circle[i][j]){
    130                         printf("%c%d: %s
    ",i+'A',j,gra[i][j].ss);
    131                     }
    132                 }
    133             }
    134         }
    135         printf("
    ");
    136     }
    137     return 0;
    138 }
  • 相关阅读:
    ElementUI 组件不支持@keyup 的解决办法
    ElementUI 实现头部组件和左侧组件效果
    ElementUI 整体页面布局
    vue路由登录拦截
    vue中使用localStorage存储信息
    ElementUI Checkbox 多选框
    vue拦截器qs
    (未完)经典Web漏洞实战演练靶场笔记
    文件包含漏洞实战靶场笔记
    文件解析漏洞总结
  • 原文地址:https://www.cnblogs.com/npugen/p/9532651.html
Copyright © 2011-2022 走看看