2015年第六届蓝桥杯C/C++程序设计本科B组省赛-格子中输出
来源:互联网 发布:淘宝充话费可以退款么 编辑:程序博客网 时间:2024/06/11 21:30
格子中输出(代码填空)
StringInGrid函数会在一个指定大小的格子中打印指定的字符串。
要求字符串在水平、垂直两个方向上都居中。
如果字符串太长,就截断。
如果不能恰好居中,可以稍稍偏左或者偏上一点。
下面的程序实现这个逻辑,请填写划线部分缺少的代码。
对于题目中数据,应该输出:
思路:在scanf里用*修饰符,是起到过滤读入的作用。比如一个有三列数值的数据,我只想得到第2列数值,可以在循环里用scanf(“%*d%d%*d”,a[i])来读入第i行的第2个数值到a[i]。
* 修饰符在printf中的含义完全不同。如果写成printf(“%6d”, 123),很多同学应该就不会陌生了,这是设置域宽的意思。同理,%6s也是域宽。* 修饰符正是用来更灵活的控制域宽。使用%*s,表示这里的具体域宽值由后面的实参决定,如printf(“%*s”,6, “abc”)就是把”abc”放到在域宽为6的空间中右对齐。
明白了 * 是用变量来控制域宽,那么这题就简单了,这里应该填写5个实参。然后字符长度的计算应该用buf而不是s,因为buf才是截断后的长度,用s的话,如果s长度超过了width-2,效果就不对了
答案:(width-strlen(s)-2)/2,"",s,(width-strlen(s)-1)/2,""
(后面的一个为减1,为了注意奇偶问题)???在这个题目里有必要吗?
/**格子中输出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);//把字符串s,复制到buf if(strlen(s)>width-2) buf[width-2]=0;//如果字符串太长,就截断 printf("+");//占一个宽度 for(i=0; i<width-2; i++) printf("-");//占width-2个宽度 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",(width-strlen(s)-2)/2,"",s,(width-strlen(s)-1)/2,""); //填空 /**************填空部分************************/ /*****在字符串 前 后 输出(width-strlen(s)-2)/2个空格****************************//****************************************************************************************/ 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;}
用strlen()函数获得字符串的长度,该函数定义在C语言的<string.h>头文件中
0 0
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 格子中输出(代码填空)
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛-格子中输出
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 奖券数目(结果填空)
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 星系炸弹(结果填空)
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 三羊献瑞(结果填空)
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 九数组分数(代码填空)
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 加法变乘法(结果填空)
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 牌型种数(结果填空)
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 移动距离(编程大题)
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 垒骰子(编程大题)
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 生命之树(编程大题)
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 牌型种数(结果填空)
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 奖券数目(结果填空)
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 奖券数目(结果填空)
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛-星系炸弹(结果填空)
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛-三羊献瑞
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛-加法变乘法
- Json和JsonP及ajax跨域的解决办法
- 外网访问原理分析
- 华为2016研发工程师编程题---删数
- SpringMVC 表单提交 页面返回400
- 创建 floating IP
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛-格子中输出
- windows7 64位无法安装dnw的驱动解决方案[转载]
- floating IP 原理分析
- VXLAN 概念(Part I)
- Java基础知识(5)
- 中国目前还未掌握的核心技术有哪些?(无图)
- BZOJ P3171[Tjoi2013]循环格
- VXLAN 概念(Part II)- 每天5分钟玩转 OpenStack(109)
- 在 ML2 中配置 VXLAN