1050 螺旋矩阵 (25 分)C语言
本题要求将给定的 N 个正整数按非递增的顺序,填入“螺旋矩阵”。所谓“螺旋矩阵”,是指从左上角第 1 个格子开始,按顺时针螺旋方向填充。要求矩阵的规模为 m 行 n 列,满足条件:m×n 等于 N;m≥n;且 m−n 取所有可能值中的最小值。
输入格式:
输入在第 1 行中给出一个正整数 N,第 2 行给出 N 个待填充的正整数。所有数字不超过 10^4,相邻数字以空格分隔。
输出格式:
输出螺旋矩阵。每行 n 个数字,共 m 行。相邻数字以 1 个空格分隔,行末不得有多余空格。
输入样例:
12
37 76 20 98 76 42 53 95 60 81 58 93
输出样例:
98 95 93
42 37 81
53 20 76
58 60 76
思路
- 首先计算行数m和列数n的值,n从根号N的整数部分开始,往前推一直到1,找到第一个满足N % n== 0的,m的值等于N/n~将N个给定的值输入数组a,并将a数组中的值按非递增排序;
- 接着建立m行n列的数组b,填充时按层数填充,一个包裹矩阵的口字型为一层,计算螺旋矩阵的层数level;
- 如果m的值为偶数,层数为m/2;
- 如果m为奇数,层数为m/2+1,所以level = m / 2 + m % 2;
- 因为是从左上角第1个格子开始,按顺时针螺旋方向填充,所以外层for循环控制层数i从0到level,内层for循环按左上到右上、右上到右下、右下到左下、左下到左上的顺序一层层填充,注意内层for循环中还要控制t <= N – 1;
- 因为如果螺旋矩阵中所有的元素已经都填充完毕,就不能再重复填充~填充完毕后,输出整个矩阵。
#include <stdio.h>
int inc(const void *a, const void *b){
	return *(int *)b - *(int *)a;
}//从大到小排序
int main(){
	int n,i,j;
	scanf("%d",&n);
	int arr[n];
	for(i=0;i<n;i++){
		scanf("%d",&arr[i]);
	}
	qsort(arr,n,sizeof(int), inc);//降序排列
	//求出行列数
	int hang,lie;
	for(hang=sqrt(n);hang<=n;hang++){
		lie=n/hang;
		if(hang*lie==n&&hang>=lie){
			break;
		}
	}
	int num[hang][lie];//螺旋矩阵数组
	int cishu=hang/2+hang%2;//每种方向最多次数,如行分左右,所以haang/2 , 当行为奇数时,有可能多1次
	int t=0;//正在填充第几个数
	for(i=0;i<cishu;i++){//四种方向,每次循环填充四种方向各一轮
		for(j=i;t<n&&j<lie-i;j++){//往右填充
			num[i][j]=arr[t++];
		}
		for(j=i+1;t<n&&j<hang-i-1;j++){//往下填充
			num[j][lie-i-1]=arr[t++];
		}
		for(j=lie-i-1;t<n&&j>=i;j--){//往左填充
			num[hang-i-1][j]=arr[t++];
		}
		for(j=hang-i-2;t<n&&j>=i+1;j--){//往上填充
			num[j][i]=arr[t++];
		}
	}
	for(i=0;i<hang;i++){//输出格式
		for(j=0;j<lie;j++){
			printf("%d",num[i][j]);
			if(j==lie-1&&i!=hang-1){
				printf("\n");
			}else if(j!=lie-1){
				printf(" ");
			}
		}
	}
	return 0;
}
1050 螺旋矩阵 (25 分)C语言的更多相关文章
- PAT (Basic Level) Practice (中文) 1050 螺旋矩阵 (25 分) 凌宸1642
		PAT (Basic Level) Practice (中文) 1050 螺旋矩阵 (25 分) 目录 PAT (Basic Level) Practice (中文) 1050 螺旋矩阵 (25 分) ... 
- PAT Basic 1050 螺旋矩阵 (25 分)
		本题要求将给定的 N 个正整数按非递增的顺序,填入“螺旋矩阵”.所谓“螺旋矩阵”,是指从左上角第 1 个格子开始,按顺时针螺旋方向填充.要求矩阵的规模为 m 行 n 列,满足条件:m×n 等于 N:m ... 
- PAT 1050 螺旋矩阵(25)(代码)
		1050 螺旋矩阵(25)(25 分) 本题要求将给定的N个正整数按非递增的顺序,填入"螺旋矩阵".所谓"螺旋矩阵",是指从左上角第1个格子开始,按顺时针螺旋方 ... 
- PAT-乙级-1050. 螺旋矩阵(25)
		1050. 螺旋矩阵(25) 时间限制 150 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 本题要求将给定的N个正整数按非递增的 ... 
- 1050. 螺旋矩阵(25) pat乙级题
		本题要求将给定的N个正整数按非递增的顺序,填入“螺旋矩阵”.所谓“螺旋矩阵”,是指从左上角第1个格子开始,按顺时针螺旋方向填充.要求矩阵的规模为m行n列,满足条件:m*n等于N:m>=n:且m- ... 
- PAT 1050. 螺旋矩阵(25)
		本题要求将给定的N个正整数按非递增的顺序,填入"螺旋矩阵".所谓"螺旋矩阵",是指从左上角第1个格子开始,按顺时针螺旋方向填充.要求矩阵的规模为m行n列,满足条 ... 
- PAT(B) 1050 螺旋矩阵(Java:24分)
		题目链接:1050 螺旋矩阵 (25 point(s)) 题目描述 本题要求将给定的 N 个正整数按非递增的顺序,填入"螺旋矩阵".所谓"螺旋矩阵",是指从左上 ... 
- PAT——1050. 螺旋矩阵
		本题要求将给定的N个正整数按非递增的顺序,填入“螺旋矩阵”.所谓“螺旋矩阵”,是指从左上角第1个格子开始,按顺时针螺旋方向填充.要求矩阵的规模为m行n列,满足条件:m*n等于N:m>=n:且m- ... 
- PAT 1050 螺旋矩阵
		https://pintia.cn/problem-sets/994805260223102976/problems/994805275146436608 本题要求将给定的 N 个正整数按非递增的顺序 ... 
随机推荐
- js判断数组或对象是否相等
			/** * 验证两个object 是否相同 * @param {Object} obj [需要进行验证的数据1] * @param {Object} newObj [需要进行验证的数据2] */ fu ... 
- Eclipse(Maven) web项目更改项目名称
			1. 右键工程:Refactor->Rename,更改项目名称: 2. 修改项目目录下:.project文件 <?xml version="1.0" encoding= ... 
- Android教程-03 常见布局的总结
			常见的布局 视频建议采用超清模式观看, 欢迎点击订阅我的优酷 Android的图形用户界面是由多个View和ViewGroup构建出来的.View是通用的UI窗体小组件,比如按钮(Button)或者文 ... 
- 洛谷P3150 pb的游戏(1)题解 博弈论入门
			题目链接:https://www.luogu.org/problem/P3150 这道题目是博弈论的入门题. 我们以 必胜态 和 必败态 来讲解这个问题. 首先,下面的图片演示了前8个数的必胜态和必败 ... 
- 微信小程序wx.request POST获取不到数据解决办法
			get //发起请求 wx.request({ url: 'http://www.xiaochengxu.com/home/index/curd', //仅为示例,并非真实的接口地 ... 
- 高可用之nginx配置文件详解
			#user nobody; worker_processes 1;##工作线程数,一般和cpu的核数相同:可通过ps -ef | nginx查看线程数 #配置错误日志位置 #error_log log ... 
- Vue 属性绑定v-bing  事件绑定v-on
			<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ... 
- Ubuntu Kylin 14.04安装
			早听说Ubuntu Kylin对中国本地做了很多定制的工作,想搜狗输入法.WPS,还有中国日历等.昨天没事就下载了一个Kylin试用了下,使用的方法还是使用EasyBCD软件做了个硬盘安装启动,关于E ... 
- java 使用反射调用方法
			每个Method的对象对应一个具体的底层方法.获得Method对象后,程序可以使用Method里面的invoke方法来执行该底层方法. Object invoke(Object obj,Object ... 
- P1037 最小公倍数
			题目描述 给你两个正整数A和B,求它们的最小公倍数. 输入格式 两个正整数 \(A,B(1 \le A,B \le 10^9)\) . 输出格式 一个整数,表示A和B的最小公倍数. 样例输入 6 8 ... 
