【水题】UVA 512 Spreadsheet Tracking
来源:互联网 发布:上海知楚 旻泉 编辑:程序博客网 时间:2024/06/06 03:08
Problem Description
给你r行c列的电子表格,给你n个操作,具体来说一共有五种操作:
EX r1 c1 r2 c2交换单元格(r1,c1),(r2,c2).
A x1 x2 …… xA 插入或删除A行或列(DC-删除列, DR-删除行, IC-插入列, IR-插入行, 1 <= A <= 10)。
接下来q个查询,给你原始的单元格(r0, c0)输出原始的,输出操作后的。
代码:
#include<bits/stdc++.h>using namespace std;struct node{ char c[5];//存操作字符串 int r1, c1, r2, c2;//交换的两个单元 int x[20], m;//存对应m个数};node a[10000];int n;int Move(int *r0, int *c0){ int i, j; for(i = 0; i < n; i++) { if(a[i].c[0] == 'E')//交换两个单元 { if(a[i].r1 == *r0 && a[i].c1 == *c0) {//下标变换一下 *r0 = a[i].r2; *c0 = a[i].c2; } else if(a[i].r2 == *r0 && a[i].c2 == *c0) { *r0 = a[i].r1; *c0 = a[i].c1; } } else { int dr = 0, dc = 0; for(j = 0; j < a[i].m; j++) { int x = a[i].x[j]; if(a[i].c[0] == 'I')//插入 { if(a[i].c[1] == 'R')//插入行 { if(x <= *r0) dr++;//插入的行在*r0上边, 所以*r0++ } if(a[i].c[1] == 'C')//插入列 { if(x <= *c0) dc++; } } else//删除 { if(a[i].c[1] == 'R')//删除行 { if(x == *r0) return 0;//一样删除了,返回0 else if(x < *r0) dr--;//删除行在*r0上边, 所以*r0-- } else { if(x == *c0) return 0; else if(x < *c0) dc--; } } } *r0 += dr; *c0 += dc; } } return 1;}int main(){ int r, c, r0, c0; int i, j, q, cas = 0; while(~scanf("%d %d %d", &r, &c, &n)) { if(!r && !c) break; for(i = 0; i < n; i++) { scanf("%s", a[i].c); if(a[i].c[0] == 'E') { scanf("%d %d %d %d", &a[i].r1, &a[i].c1, &a[i].r2, &a[i].c2); } else { scanf("%d", &a[i].m); for(j = 0; j < a[i].m; j++) scanf("%d", &a[i].x[j]); } } scanf("%d", &q); if(cas > 0) printf("\n"); printf("Spreadsheet #%d\n", ++cas); while(q--) { scanf("%d %d", &r0, &c0); printf("Cell data in (%d,%d) ", r0, c0); if(!Move(&r0, &c0)) printf("GONE\n"); else { printf("moved to (%d,%d)\n", r0, c0); } } } return 0;}
0 0
- 【水题】UVA 512 Spreadsheet Tracking
- UVA - 512 Spreadsheet Tracking
- Uva - 512 - Spreadsheet Tracking
- UVA - 512 Spreadsheet Tracking
- UVA-512 Spreadsheet Tracking
- UVa 512 Spreadsheet Tracking
- uva 512 Spreadsheet Tracking
- UVa 512 Spreadsheet Tracking
- UVa 512 Spreadsheet Tracking
- UVa 512 - Spreadsheet Tracking
- UVa 512 Spreadsheet Tracking
- 例题4-5 uva 512 - Spreadsheet Tracking
- UVa 512 - Spreadsheet Tracking (模拟)
- 紫书章四 Spreadsheet Tracking UVA
- 512 - Spreadsheet Tracking
- 512 - Spreadsheet Tracking
- 512 - Spreadsheet Tracking
- 512 - Spreadsheet Tracking
- 测试也需要懂尼尔森的十大可用性原则
- vb中 打开文件夹浏览框的方法总结
- jdk版本导致的类型转换异常
- bzoj2301 [HAOI2011]Problem b (莫比乌斯函数)
- javascript的基本语法
- 【水题】UVA 512 Spreadsheet Tracking
- hadoop伪分布式环境搭建
- C#MVC视图获取modle实体类中的参数
- PHP+smarty对checkbox的初始化和绑定
- C Primer Plus 第6章 C控制语句:循环 编程练习
- GPS定位\基站定位\WiFi辅助定位及其其他定位原理详解
- 如何选择 损失函数 Loss Function
- Android中获取正在运行的应用程序-----ActivityManager.RunningAppProcessInfo类详解
- JS 如何创建对象、数据类型