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

本文共 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/7564353.html

你可能感兴趣的文章
date命令的详细用法!
查看>>
分布式存储ceph集群部署
查看>>
UiAutomator源码分析之UiAutomatorBridge框架
查看>>
python 开发之selenium
查看>>
Xcode3.2.5中找不到Mac OS X - Command Line Utility -...
查看>>
css的div垂直居中的方法,百分比div垂直居中
查看>>
如何理解EM算法
查看>>
nginx 域名跳转一例~~~(rewrite、proxy)
查看>>
linux用户家目录无损迁移到独立硬盘
查看>>
文件查找
查看>>
shell编程前言(一)
查看>>
5、centos7.*配置yum的EPEL源及其它源
查看>>
JSON前后台简单操作
查看>>
shell中一些常见的文件操作符
查看>>
CentOS 7 装vim遇到的问题和解决方法
查看>>
JavaScript基础教程1-20160612
查看>>
使用第三方类、库需要注意的正则类RegexKitLite的使用
查看>>
iOS \U7ea2 乱码 转换
查看>>
FCN图像分割
查看>>
ios xmpp demo
查看>>