博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CSP考试 2015年3月第1题 图像旋转 C语言实现
阅读量:2241 次
发布时间:2019-05-09

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

题目分析:

该题是对一个输入的矩阵逆时针旋转之后求得到的矩阵,对于矩阵想到可以使用二维数组,但是这里的题目要求则不能使用数组天然的位序,(关于数组天然位序的应用,可以查看我的博客:) ,那么关键就在于对二维数组的构造,以及旋转操作,分析逆时针旋转可以发现,行序变列序,也就是说,第一行在实际输出时需要按第一列输出,但是问题在于第一列他不能直接输出,所以可以从行数末尾从后往前输出,先减小行数再减小列数,使用二重循环来实现。

C语言源程序:

#include
int main(){ int m,n,i,j,v; scanf("%d%d",&m,&n); short num[m][n]; for(i=0;i

在上述程序中,对于数组的定义是可以直接将scanf赋值后的变量作为声明的,还可以直接在定义数组前将并阿联复制也是一样的效果,下面时用define定义的最大数组长度,但是当我使用int定义数组变量时发现,C语言中不能容纳1000*1000的int型数组,随后我又改为short型才正确通过。

#include
#define N 1000int mmain(){ int m,n,i,j,v; //数组类型需要改为short型 short num[N][N]; scanf("%d%d",&m,&n); for(i=0;i

运行结果:

转载地址:http://zchbb.baihongyu.com/

你可能感兴趣的文章
一个字节等于多少位?
查看>>
帧框架frameset的用法总结
查看>>
java1.8中创建hashmap的初始化大小设置标准
查看>>
mark一下,service的实现层没有加@service注解。
查看>>
jq对象转换成js对象。已经jq的复合选择器。
查看>>
(一)alin‘s mysql学习笔记----概述
查看>>
(二)alin’s mysql学习笔记----mysql的存储引擎
查看>>
(三)alin’s mysql学习笔记----常用的join连接查询
查看>>
(四)alin’s mysql学习笔记----索引简介
查看>>
分布式系统中的幂等性的理解
查看>>
spring的注解开发中的常用注解(一)------@bean @Configuration @ComponentScan @Import @Scope @Lazy
查看>>
(五)alin’s mysql学习笔记----索引性能分析
查看>>
Spring中使用@Transactional注解进行事务管理的时候只有应用到 public 方法才有效
查看>>
springboot整合rabbitmq及rabbitmq的简单入门
查看>>
mysql事务和隔离级别笔记
查看>>
事务的传播属性(有坑点)自调用失效学习笔记
查看>>
REDIS缓存穿透,缓存击穿,缓存雪崩原因+解决方案
查看>>
动态代理实现AOP
查看>>
23种常见的java设计模式
查看>>
关于被final修饰的基本数据类型一些注意事项
查看>>