山东省第六届蓝桥杯 ///标题:格子中输出//c/c++组
2015-12-17 15:04
561 查看
格子中输出
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;
}
对于题目中数据,应该输出:
+------------------+
| |
| abcd1234 |
| |
| |
+------------------+
注意:只填写缺少的内容,不要书写任何题面已有代码或说明性文字。
答案:
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;
}
对于题目中数据,应该输出:
+------------------+
| |
| abcd1234 |
| |
| |
+------------------+
注意:只填写缺少的内容,不要书写任何题面已有代码或说明性文字。
答案:
(width-strlen(s)-2)/2," ",s,(width-strlen(s)-1)/2," "
#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; }
相关文章推荐
- c++跨平台读取根盘符文件路径到前台
- 山东省第六届蓝桥杯 ///标题:三羊献瑞//c/c++组
- 山东省第六届蓝桥杯 ///标题:星系炸弹//c/c++组
- VC++中字符串编码的转换
- C++条件状态 判别输入问题
- 第14周项目3 验证算法—二叉排序树相关算法
- C语言实现C到C++的注释转换
- 山东省第六届蓝桥杯 ///标题:奖券数目//c/c++组
- 探究C++中string类的实现原理以及扩展使用
- C++11的新特性 Lambda 函数
- C语言中的struct和typedef struct<转载>
- 【C++ STL应用与实现】0: 感恩STL——STL, ACM和年轻的我们
- 第14周项目2 算法验证—分块查找算法
- c++ 获取当前用户的根目录
- 第14周项目1 验证算法—折半查找算法
- 个人项目--C语言游戏
- 第13周项目3 算法验证—Floyd算法
- 第13周项目2 算法验证—Dijkstra算法
- 第13周项目1 算法验证—Prim算法+Kruskal算法
- C语言_螺旋输出