当前位置: 首页 > news >正文

P5721 【深基4.例6】数字直角三角形

思路分析:

  1.   可以把这个任务分成两个层级:大任务输出每一行,小任务输出每一行的每个数字。
  2. 对于大任务来说,需要一个外层循环,其循环体就是输出一行的内容;对于小任务来说,需要一个内层循环,用于输出一行中的每个数字。
  3. 本题一共需要输出n行,所以外循环可以是从1~n(也可以0~n-1)。当处理第i行时,需要输出n-i+1个数字。在前面定义一个cnt来记录输出到什么地方了。

代码一:

#include <iostream>
using namespace std;
int main(){int n;scanf("%d",&n);int cnt=0;for(int i=1;i<=n;i++){for(int j=1;j<=n-i+1;j++)printf("%02d",++cnt);printf("\n");}return 0;	
}

代码中的printf函数用于格式化输出数字,其中%02d表示输出的整数至少占用两位宽度,不足部分以0填充。这是为了保持输出的对齐。

代码二:

#include <iostream>  
#include <iomanip> // 用于std::setw和std::setfill  using namespace std;  int main() {  int n;  cin >> n;  int cnt = 0;  for (int i = 1; i <= n; ++i) {  for (int j = 1; j <= n - i + 1; ++j) {  cout << setw(2) << setfill('0') << ++cnt; // 使用setw和setfill来格式化输出  }  cout << endl;  }  return 0;  
}

附:printf格式控制符的完整格式

1. 格式修饰符:

1)%-:在字段宽度中,表示左对齐输出,如省略表示右对齐输出。
2)%+:正数前面加上正号。
3)%0:在字段宽度中,用0填充空白位置,如省略表示指定空位不填。
4)%m.n:m指域宽,即对应的输出项在输出设备上所占的字符数。n指精度。用于说明输出的实型数的小数位数。未指定n时,隐含的精度为n=6位。
5)%*:用于指定字段宽度为动态值,例如%*d表示使用变量值作为字段宽度。比如:

char ch[20];
printf("%*.*s\n",m,n,ch);
前边的*定义的是总的宽度,后边的定义的是输出的个数。分别对应外面的参数m和n 。

6)%l或h:l对整型指long型,对实型指double型。h用于将整型的格式字符修正为short型。

2. 格式控制符:

1) d格式:用来输出十进制整数。有以下几种用法:

  • %d:按整型数据的实际长度输出。
  • %md:m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。
  • %ld:输出长整型数据。

2)o格式:以无符号八进制形式输出整数。对长整型可以用"%lo"格式输出。同样也可以指定字段宽度用“%mo”格式输出。

3)x格式:以无符号十六进制形式输出整数。对长整型可以用"%lx"格式输出。同样也可以指定字段宽度用"%mx"格式输出。

4)u格式:以无符号十进制形式输出整数。对长整型可以用"%lu"格式输出。同样也可以指定字段宽度用“%mu”格式输出。

5)c格式:输出单个字符。

6)s格式:用来输出一个串。有几种用法:

  • %s:例如:printf("%s", "CHINA")输出"CHINA"字符串(不包括双引号)。
  • %ms:输出的字符串占m列,如字符串本身长度大于m,则突破获m的限制,将字符串全部输出。若串长小于m,则左补空格。
  • %-ms:如果串长小于m,则在m列范围内,字符串向左靠,右补空格。
  • %m.ns:输出占m列,但只取字符串中左端n个字符。这n个字符输出在m列的右侧,左补空格。
  • %-m.ns:其中m、n含义同上,n个字符输出在m列范围的左侧,右补空格。如果n>m,则自动取n值,即保证n个字符正常输出。

7)f格式:用来输出实数(包括单、双精度),以小数形式输出。有以下几种用法:

  • %f:不指定宽度,整数部分全部输出并输出6位小数。
  • %m.nf:输出共占m列,其中有n位小数,如数值宽度小于m左端补空格。 
  • %-m.nf:输出共占n列,其中有n位小数,如数值宽度小于m右端补空格。
  • 其中,对于单精度数,使用%f格式符输出时,仅前7位是有效数字,小数6位。对于双精度数,使用%lf格式符输出时,前16位是有效数字,小数6位.

8)e格式:以指数形式输出实数。可用以下形式:

  • %e:数字部分(又称尾数)输出6位小数,指数部分占5位或4位。
  • %m.ne和%-m.ne:m、n和”-”字符含义与前相同。此处n指数据的数字部分的小数位数,m表示整个输出数据所占的宽度。

9)g格式:自动选f格式或e格式中较短的一种输出,且不输出无意义的零。
 

附:C++ 标准库 <iomanip>

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 【uniapp/uview1.x】u-collapse 高度随内容自适应
  • 13.DataLoader 的使用
  • 三级_网络技术_52_应用题
  • 深度学习中Embedding的理解
  • pytorch的继承方法
  • 探索数字沙龙——文本描述生成数字人3D发型的专业工具
  • 数据结构与算法再探(二)高精度计算
  • ActiveMQ指南
  • SpringBoot项目目录介绍(SpringBoot学2)
  • pycharm中opencv-python和opencv-contrib安装
  • 【XR】SDK的接口规划与设计
  • K8S对接Ceph分布式存储
  • apache服务器的配置(服务名httpd,端口80 , 443)
  • Ubuntu安装交叉编译工具链(gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu)
  • 中文乱码解决方案
  • docker python 配置
  • maya建模与骨骼动画快速实现人工鱼
  • miniui datagrid 的客户端分页解决方案 - CS结合
  • Quartz初级教程
  • Spring-boot 启动时碰到的错误
  • Swift 中的尾递归和蹦床
  • Terraform入门 - 3. 变更基础设施
  • 案例分享〡三拾众筹持续交付开发流程支撑创新业务
  • 基于axios的vue插件,让http请求更简单
  • 将 Measurements 和 Units 应用到物理学
  • 让你成为前端,后端或全栈开发程序员的进阶指南,一门学到老的技术
  • 深入浏览器事件循环的本质
  • 微服务核心架构梳理
  • 一些基于React、Vue、Node.js、MongoDB技术栈的实践项目
  • Hibernate主键生成策略及选择
  • 没有任何编程基础可以直接学习python语言吗?学会后能够做什么? ...
  • ​LeetCode解法汇总1410. HTML 实体解析器
  • ​字​节​一​面​
  • $$$$GB2312-80区位编码表$$$$
  • $forceUpdate()函数
  • (51单片机)第五章-A/D和D/A工作原理-A/D
  • (C语言版)链表(三)——实现双向链表创建、删除、插入、释放内存等简单操作...
  • (阿里巴巴 dubbo,有数据库,可执行 )dubbo zookeeper spring demo
  • (多级缓存)多级缓存
  • (力扣记录)235. 二叉搜索树的最近公共祖先
  • (十一)手动添加用户和文件的特殊权限
  • (实战)静默dbca安装创建数据库 --参数说明+举例
  • (收藏)Git和Repo扫盲——如何取得Android源代码
  • (小白学Java)Java简介和基本配置
  • (源码分析)springsecurity认证授权
  • (转)h264中avc和flv数据的解析
  • ***linux下安装xampp,XAMPP目录结构(阿里云安装xampp)
  • .bat批处理(九):替换带有等号=的字符串的子串
  • .cfg\.dat\.mak(持续补充)
  • .net core + vue 搭建前后端分离的框架
  • .net core webapi Startup 注入ConfigurePrimaryHttpMessageHandler
  • .NET Core、DNX、DNU、DNVM、MVC6学习资料
  • .NET Framework与.NET Framework SDK有什么不同?
  • .NET Standard、.NET Framework 、.NET Core三者的关系与区别?
  • .NET面试题(二)