博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UVALive5198 UVA512 Spreadsheet Tracking
阅读量:7043 次
发布时间:2019-06-28

本文共 1022 字,大约阅读时间需要 3 分钟。

World Finals >> 1997 - San Jose

问题链接:。

问题简述:这是一个电子表格操作的模拟题。先输入电子表格总的行和列的正整数r和c,满足r,c<=50,r和c均为0时,输入测试实例结束;然后输入命令数n,跟着是n条命令,包括:

1. EX r1 c1 r2 c2,其含义是两个单元交换,即<r1,c1>和<r2,c2>内容交换;

2. 插入和删除命令,共4条,分别是DC(删除列)、DR(删除行)、IC(插入列)和IR(插入行),其格式如下:

< command > A x1 x2 . . . xA

其中,A为正整数,值小于10,指定其后列表xi的元素个数;列表x为删除或插入的行或列(是行还是列由命令决定)。

然后输入一个单元数,其后跟着若干个单元(r,c),r和c分别是单元的行和列坐标。对于每一个单元坐标,计算输出执行上面的命令序列之后,左边变为多少?

问题分析:采用先读入命令序列,再进行重复模拟的工作方式,相对而言比较易于理解和实现。

程序说明:结构数组cmd[]用于存储电子表格命令,枚举语句(enum operation {EX, DC, DR, IC, IR};)用于将命令转换为整数形式,函数simulate()用于模拟命令的执行。

AC的C语言程序如下:

/* UVALive5198 UVA512 Spreadsheet Tracking */#include 
#include
#define MAXN 50#define MAXN2 10#define MAXN3 10000int grid[MAXN+1][MAXN+1];enum operation {EX, DC, DR, IC, IR};struct { int cmd; int a, x[MAXN2+1];} cmd[MAXN3];int ccount;int cmp(const void *a,const void *b){ return *(int*)a - *(int*)b;}void getax(int index){ int i; scanf("%d", &cmd[index].a); for(i=0; i

转载于:https://www.cnblogs.com/tigerisland/p/7564354.html

你可能感兴趣的文章
NetCore +EFCore+SqlServer根据数据库生成实体类到项目中
查看>>
jquery实现图片切换和js实现图片切换
查看>>
Android DatePickerDialog 使用方法
查看>>
python 3使用binascii方法的报错解决
查看>>
C#编程实践--字符串反转
查看>>
使用Chrome远程调试GenyMotion上的WebView程序
查看>>
网站架构文章收集
查看>>
bzoj1003(ZJOI2006)物流运输
查看>>
洛谷2593 [ZJOI2006]超级麻将——可行性dp
查看>>
结对项目----四则运算“软件”升级版
查看>>
Swift 通用类型和通用函数 | Generic type and function
查看>>
phpcms v9 商品购物车模块 不影响升级 二次开发
查看>>
linux下C语言实现文件传输的简单实例
查看>>
C++ 简单实现MFC ListControl 点击列头排序
查看>>
关于兼容
查看>>
第三章:绑定语法(1)
查看>>
操作系统学习笔记:安全
查看>>
【Dijkstra模板】codeforces715B Complete The Graph(最短路径)
查看>>
例题9-10 UVa1626&&POJ1141 Brackets Sequence(DP)
查看>>
【转载】消息队列技术介绍
查看>>