蓝桥杯 历届试题 格子中输出(%*s的使用)
2018-03-31 17:14
337 查看
格子中输出
StringInGrid函数会在一个指定大小的格子中打印指定的字符串。
要求字符串在水平、垂直两个方向上都居中。
如果字符串太长,就截断。
如果不能恰好居中,可以稍稍偏左或者偏上一点。
下面的程序实现这个逻辑,请填写划线部分缺少的代码。
对于题目中数据,应该输出:
(如果出现对齐问题,参看【图1.jpg】)
注意:只填写缺少的内容,不要书写任何题面已有代码或说明性文字。
ps: %*s是对s最小域宽的控制,格式为右对齐
StringInGrid函数会在一个指定大小的格子中打印指定的字符串。
要求字符串在水平、垂直两个方向上都居中。
如果字符串太长,就截断。
如果不能恰好居中,可以稍稍偏左或者偏上一点。
下面的程序实现这个逻辑,请填写划线部分缺少的代码。
#include <stdio.h> #include <string.h> void StringInGrid(int width, int height, const char* s) { int i,k; char buf[1000]; strcpy(buf, s); if(strlen(s)>width-2) buf[width-2]=0; printf("+"); for(i=0;i<width-2;i++) printf("-"); printf("+\n"); for(k=1; k<(height-1)/2;k++){ printf("|"); for(i=0;i<width-2;i++) printf(" "); printf("|\n"); } printf("|"); printf("%*s%s%*s",_____________________________________________); //填空 printf("|\n"); for(k=(height-1)/2+1; k<height-1; k++){ printf("|"); for(i=0;i<width-2;i++) printf(" "); printf("|\n"); } printf("+"); for(i=0;i<width-2;i++) printf("-"); printf("+\n"); } int main() { StringInGrid(20,6,"abcd1234"); return 0; }
对于题目中数据,应该输出:
(如果出现对齐问题,参看【图1.jpg】)
注意:只填写缺少的内容,不要书写任何题面已有代码或说明性文字。
ps: %*s是对s最小域宽的控制,格式为右对齐
printf("%*s, num, str);[/code]//num代表字符串str的最小长度
举个简单的例子:
#include<iostream>
#include<cstdio>
using namespace std;
int main()
{
char str[10] = "hello!";
printf("%*s", 10, str);//输出的字符串长度应至少是10,对于这个例子,输出的长度是10
return 0;
}
结果:
回到这道题目,输出的图形每行的宽度为width, 那么两边的空格长度=(width−strlen(buf)−2)/2两边的空格长度=(width−strlen(buf)−2)/2; buf为要输出的字符串,因为%*s是控制字符串的长度的,题目的输出为"printf("%*s%s%*s",_____________________________________________); //填空
,说明应该输出三个字符串,那么第一个%*s 可以是左边的空格长度 + buf的长度(总长度为(width+strlen(buf)−2)/2总长度为(width+strlen(buf)−2)/2),第二个%s可以是”“(空字符串),那么剩下第三个%*s,就是空字符串(长度为(width−strlen(buf)−2)/2(width−strlen(buf)−2)/2).
因此,最后答案为:(width + strlen(buf) - 2) / 2, buf, "",(width - strlen(buf) - 2)/2,""
这里顺带提一下%*d, 它的作用就是过滤输入内容。
比如scanf("%*d%d, &a);
输入1 5, 那么最后的a等于5,1被过滤了
相关文章推荐
- 蓝桥杯--历届试题 剪格子(DFS)
- 蓝桥杯 历届试题 剪格子
- [蓝桥杯] 历届试题 剪格子(dfs+回溯)
- 蓝桥杯 历届试题 剪格子
- 第六届蓝桥杯【省赛试题4】格子中输出
- 蓝桥杯:历届试题 剪格子【JAVA算法实现】
- 历届试题 剪格子 蓝桥杯
- 蓝桥杯 历届试题 兰顿蚂蚁(模拟 + map的使用)
- 蓝桥杯 历届试题 剪格子(dfs搜索)
- 【蓝桥杯】历届试题 剪格子(未完成)
- 蓝桥杯 历届试题 4. 剪格子
- 蓝桥杯-- 历届试题 剪格子(dfs)
- 蓝桥杯 历届试题 剪格子 (dfs)
- 蓝桥杯 历届试题 格子刷油漆
- 蓝桥杯 历届试题 剪格子
- 蓝桥杯 历届试题 剪格子 (dfs回溯)
- 蓝桥杯 历届试题 打印十字图(模拟水题,图形输出)
- <历届试题>蓝桥杯之格子刷油漆
- 蓝桥杯-历届试题-格子刷油漆
- 蓝桥杯历届试题 剪格子