2015年第六届蓝桥杯C/C++程序设计本科B组省赛 格子中输出(代码填空)
2016-01-24 13:16
537 查看
2015年第六届蓝桥杯C/C++程序设计本科B组省赛题目汇总:
/article/7584760.html
格子中输出
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,为了注意奇偶问题)
最终结果:
/article/7584760.html
格子中输出
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; }
对于题目中数据,应该输出:
思路:在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,为了注意奇偶问题)
最终结果:
#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", (width-strlen(s)-2)/2,"",s,(width-strlen(s)-1)/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; }
相关文章推荐
- 1057. Stack (30)
- C++简单例子说明一个问题
- c++ diary3
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 三羊献瑞(结果填空)
- Educational Codeforces Round 6:(620)
- C++:泛型编程vector(排序)
- 毕业后的C++学习笔记
- C++:泛型编程stack(括号匹配)
- Leetcode 35 - Search Insert Position
- C++:泛型编程set(排序去重)
- C++ 蓝桥杯基础训练 10进制转16进制
- c语言中const volatile关键字 和 elf section的关系
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 星系炸弹(结果填空)
- C++中函数如何返回数组
- C++中的四舍五入
- c++实现atoi()和itoa()函数(字符串和整数转化)
- 纵横字谜的答案(uva 232)
- Leetcode 34 - Search for a Range
- 2015年第六届蓝桥杯C/C++程序设计本科B组省赛 奖券数目(结果填空)
- (入门) uva 10340 All in all