c 语言基础题目:L1-039 古风排版

2023-10-17 00:04

本文主要是介绍c 语言基础题目:L1-039 古风排版,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        中国的古人写文字,是从右向左竖向排版的。本题就请你编写程序,把一段文字按古风排版。

输入格式:

        输入在第一行给出一个正整数N(<100),是每一列的字符数。第二行给出一个长度不超过1000的非空字符串,以回车结束。

输出格式:

        按古风格式排版给定的字符串,每列N个字符(除了最后一列可能不足N个)。

输入样例:

4
This is a test case

输出样例:

asa T
st ih
e tsice s

程序源码: 

// 这一行用于关闭某些C运行时库的安全警告。  
#define _CRT_SECURE_NO_WARNINGS  // 包含标准输入输出库,本程序使用到的printf和scanf函数均来源于此库  
#include <stdio.h>  // 定义主函数,C语言程序的入口  
int main() {  // 定义一个字符数组,用于存储用户输入的字符串  char buf[1001];  // 定义一个整型变量,用于接收用户输入的整数N  int N;  // 使用scanf函数从标准输入读取一个整数并存储到N变量中  scanf("%d", &N);  // 使用gets函数(这个函数在最新的C标准中已被废弃,建议使用fgets代替)从标准输入读取一行字符串并存储到buf数组中  // 注意,这里没有任何输入过滤和错误处理,如果输入的字符串超过了buf的大小(1001),那么就可能导致缓冲区溢出,这是一个潜在的安全隐患  gets(buf);  // 再使用gets函数读取一次字符串,同样存在安全问题,且这部分代码实际上并未被使用,可以删除  gets(buf);  // 使用strlen函数计算字符串的长度  int len = strlen(buf);  // 计算N行的总行数,算法为len除以N,如果len除以N有余数,则总行数加1  int line = len/N+(len%N!=0?1:0);  // 外层循环,控制行数,从0到N-1  for (int i = 0; i < N; i++)  {  // 内层循环,控制每行的字符数,从0到line-1  for (int j = 0; j < line; j++)  {  // 判断如果((line - j - 1) * N) + i小于len,即这个字符在buf中存在,则打印这个字符,否则打印空格  if(((line - j - 1) * N) + i<len)  printf("%c",buf[((line-j-1) * N)+i]);  else  printf(" ");  }  // 每打印完一行后换行  printf("\n");  }     // 主函数返回0,表示程序正常结束  return 0;  
}

解题思路:

1.读取与存储:使用gets读取存储下来;

2.我们将其想象为一个二位的字符数组,根据下标的规律输出来即可。假定输入N=3 和012345678古风排版是

630
741
852

我们看到它的规律就是

(列数)*N......1*N0*N
(列数)*N+1......1*N+10*N+1
(列数)*N+2......1*N+20*N+2

        所以我们按这个规律输出即可,我们的列数是可以通过总字符的格式计算出来的,行数固定,通过列数=字符/行数,其中如果字符/行数不等与0,代表需要在加上一列。

第一列输出空格,这可以通过下标判断是否越界,如果越界输出空格,如果没有正常输出即可。

这篇关于c 语言基础题目:L1-039 古风排版的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/221615

相关文章

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close

题目1254:N皇后问题

题目1254:N皇后问题 时间限制:1 秒 内存限制:128 兆 特殊判题:否 题目描述: N皇后问题,即在N*N的方格棋盘内放置了N个皇后,使得它们不相互攻击(即任意2个皇后不允许处在同一排,同一列,也不允许处在同一斜线上。因为皇后可以直走,横走和斜走如下图)。 你的任务是,对于给定的N,求出有多少种合法的放置方法。输出N皇后问题所有不同的摆放情况个数。 输入

题目1380:lucky number

题目1380:lucky number 时间限制:3 秒 内存限制:3 兆 特殊判题:否 提交:2839 解决:300 题目描述: 每个人有自己的lucky number,小A也一样。不过他的lucky number定义不一样。他认为一个序列中某些数出现的次数为n的话,都是他的lucky number。但是,现在这个序列很大,他无法快速找到所有lucky number。既然

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX