7-8 矩阵字符

给定一个仅包含小写字母的字符串S,用这些字符恰好排成一个n行m列的矩阵(m≥n),请找出所有符合要求的矩阵中最接近于正方形的那个矩阵。然后从第一列开始,逐列按照从上到下的顺序输出矩阵中的字符。

例如:S = "abcdefgh"。按要求m≥n有如下两种矩阵:

第一种:

第二种:

最接近正方形的矩阵是第一种。从第一列开始,逐列按照从上到下的顺序输出矩阵中的字符,结果为: aebfcgdh。

输入格式:

输入一个字符串,仅包含小写字母且长度不超过200。

输出格式:

请找出符合题目要求的最接近正方形的字符矩阵,从第一列开始,逐列按照从上到下的顺序输出矩阵中的字符

输入样例:

在这里给出一组输入。例如:

复制代码
abcdefgh

输出样例:

在这里给出相应的输出。例如:

复制代码
aebfcgdh

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

栈限制

8192 KB

复制代码
//#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include<math.h>

#define MAX 300
char A[MAX];
int num[MAX] = { 0 };
char B[50][50];

int function(int count);

int main()
{
    gets(A);
    int count = strlen(A);
    int panduan = function(count);
    //printf("%d", panduan);
    if (panduan == 1||count == 1||count == 2)
    {
        puts(A);
    }
    else
    {
        int th = 0;
        for (int i = 2; i <= sqrt(count); i++)
        {
            if (count % i == 0)
            {
                num[th] = i;
                th++;
            }
        }
        //printf("%d", num[th - 1]);
        int p = count / num[th - 1];
        //printf("%d\n", p);
        for (int i = 0; i < num[th - 1]; i++)
        {
            for (int j = 0; j < p; j++)
            {
                B[i][j] = A[j + i * p];
            }
            //printf("\n");
        }
        for (int i = 0; i < p; i++)
        {
            for (int j = 0; j < num[th - 1]; j++)
            {
                printf("%c", B[j][i]);
            }
            //printf("\n");
        }
    }
}

int function(int count)
{
    if (count == 1)
        return 0;
    if (count == 2)
        return 1;
    for (int i = 2; i <= sqrt(count); i++)
    {
        if (count % i == 0)
            return 0;
    }
    return 1;
}
相关推荐
Evand J2 小时前
【MATLAB代码介绍】三维环境下的IMM(交互式多模型),使用CV和CT模型,EKF作为滤波,目标高精度、自适应跟踪定位
开发语言·算法·matlab·imm·代码介绍
ZC跨境爬虫2 小时前
3D 地球卫星轨道可视化平台开发 Day12(解决初始相位拥挤问题,实现卫星均匀散开渲染)
前端·javascript·算法·3d·json
子午2 小时前
蔬菜识别~Python+深度学习+卷积网络算法+图像识别+2026原创+蔬菜识别
python·深度学习·算法
子午2 小时前
文本情感识别系统~Python+textCNN算法+深度学习+人工智能
人工智能·python·算法
pearlthriving2 小时前
STL容器及其底层
开发语言·c++·算法
博.闻广见2 小时前
AI_线性代数-6.PCA降维详解
人工智能·线性代数
念越2 小时前
算法每日一题 Day04|快慢双指针法解决环形链表问题
数据结构·算法·链表
张人玉2 小时前
VisionPro 药物检测工具 学习笔记
算法·c#·机器视觉·vsionpro
_深海凉_2 小时前
LeetCode热题100-前 K 个高频元素
算法·leetcode·职场和发展
周末也要写八哥2 小时前
深度剖析:动态规划的分类及实例
算法·动态规划