首页 > 其他分享 >顺时针打印二维数组

顺时针打印二维数组

时间:2023-03-11 22:45:54浏览次数:38  
标签:顺时针 数组 int while 二维 && include 不变

我的代码
思路:用循环模拟,碰壁之后转弯

#include<stdio.h>
#include<stdlib.h>

int main(){
    int n;
    scanf("%d",&n);
    int**a=(int**)malloc(n*sizeof(int*));
    for(int i=0;i<n;i++){
        a[i]=(int*)malloc(n*sizeof(int));
        for(int j=0;j<n;j++)
            a[i][j]=-1;
    }
    int m=1;
    int i=0,j=0;
    while(a[i][j]==-1&&m<n*n){
        while(j<n-1&&a[i][j+1]==-1)
        {
            a[i][j]=m++;
            j++;
        }
        while(i<n-1&&a[i+1][j]==-1)
        {
            a[i][j]=m++;
            i++;
        }
        while(j>0&&a[i][j-1]==-1)
        {
            a[i][j]=m++;
            j--;
        }
        while(i>0&&a[i-1][j]==-1){
            a[i][j]=m++;
            i--;
        }
    }
    a[i][j]=m;
    for(int i=0;i<n;i++){
        for(int j=0;j<n;j++)
            printf("%3d",a[i][j]);
        printf("\n");
    }
}

其他思路(他人):使用记录与所在头朝向有关的位置变化的数组
朝右时:行不变,列+1
朝下时:行+1,列不变
朝左时:行不变,列-1
朝上时:行-1,列不变
重复以上四个步骤,可用取余实现

#include<cstdio>
using namespace std;
int read(){//没啥用的快读
	int x=0,f=1;
	char c=getchar();
	while(c<'0'||c>'9'){
		if(c=='-') f=-1;
		c=getchar();
	}
	while(c>='0'&&c<='9'){
		x=x*10+c-'0';
		c=getchar();
	}
	return x*f;
}
int a[15][15];//记录输出的数组
int pos[4][2]={0,1,1,0,0,-1,-1,0};//改变位置的数组
int main(){//主函数
	int n=read(),x=1,y=1,d=0;//初始化
	for(int i=1;i<=n*n;i++){//遍历
		a[x][y]=i;//赋值
		int tx=x+pos[d][0],ty=y+pos[d][1];//核心代码,解释见上
		if(tx<1||tx>n||ty<1||ty>n||a[tx][ty]) d=(d+1)%4;
		x+=pos[d][0],y+=pos[d][1];
	}
	for(int i=1;i<=n;i++){//输出
		for(int j=1;j<=n;j++) printf("%3d",a[i][j]);//注意%3d
		if(i<n) printf("\n");
	}
	return 0;//华丽结束
}

标签:顺时针,数组,int,while,二维,&&,include,不变
From: https://www.cnblogs.com/hithin/p/17120508.html

相关文章

  • 双指针技巧数组题目
    题目难度要点删除有序数组中的重复项●快指针与慢指针值不同,那么应该将值放在慢指针下一位移除元素●快指针对应值若不需移除,那么应该将值放在当前慢指针......
  • 2023-03-11 Java中的动态数组
    类似C++中的vector,动态数组需要满足以下功能增(insert)删(remove)改(set)查(get和contain)支持泛型自动扩容和缩容上面的实现实际相当于JDK标准库中的java.util......
  • 使用反射拷贝数组
      publicstaticvoidmain(String[]args){    int[]arr={1,2,3};    int[]obj=(int[])goodCopyOf(arr,1);    System.out.prin......
  • 对象、数组、字符串的一些方法(笔记)
    对象字符串方法数组方法 ......
  • C多级指针与多维数组
    使用指针访问数组指针类型的加减运算可以使指针内保存的首地址移动。指针类型加n后。首地址向后移动n*步长字节。指针类型减n后。首地址向前移动n*步长字节。步......
  • 二维数组打印的两种方式
    #include<stdio.h>voidprint1(intarr[3][5],intx,inty){//传统打印方式inti=0;for(i=0;i<x;i++){intj=0;for(j=0;j<y;j++){......
  • 数组模拟链表
    单链表数组模拟链表比动态链表效率更高。\(head\)作为指向头结点的指针,\(idx\)作为当前结点索引,每次执行完操作都要idx++;数组\(e[]\)用来保存当前结点的值,\(ne[......
  • 1059.使数组和能被P整除
    给你一个长度为n的整数数组nums和一个整数p,请你选出一个非空的子数组使得该子数组元素和对p的余数是0,但不能选出全部元素。计算这个子数组的长度,如果不存在这样......
  • 代码随想录-数组
    二分查找704.二分查找-力扣(LeetCode)intsearch(int*nums,intnumsSize,inttarget){intleft=0;intright=numsSize-1;intmid=0;i......
  • 寻找两个正序数组的中位数
    寻找两个正序数组的中位数 给定两个大小分别为 m 和 n 的正序(从小到大)数组 nums1 和 nums2。请你找出并返回这两个正序数组的 中位数 。算法的时......