CCF基础P54练习题解

原创 2017年01月03日 17:57:39

练习1

#include <string>
#include <iostream>
#include <cctype>
using namespace std;

bool judge(string s) {
    if(!isalpha(s[0])) {
        return false;
    }
    string::iterator it = s.begin();
    for(; it != s.end(); ++it) if(!isdigit(*it) && !isalpha(*it) && *it != '_') return false;
    return true;
}

int main() {
    string s;
    cin >> s;
    cout << (judge(s) ? "yes" : "no");
    return 0;
}

练习2

#include <string>
#include <iostream>
#include <cctype>
using namespace std;
int number[30] = {0};

void count(string s) {
    string::iterator it = s.begin();
    for(; it != s.end(); it++) {
        if(isupper(*it)) number[*it - 'A']++;
    }
}

int main() {
    string s;
    while(getline(cin, s)) {
        count(s);
    }

    int max = 0, i;
    for(i = 0; i < 26; i++) if(number[i] > max) max = number[i];

    int j;
    for(i = max; i > 0; i--) {
        for(j = 0; j < 26; j++) printf("%c ", (number[j] >= i) ? '*' : ' ');
        printf("\n");
    }

    printf("A B C D E F G H I J K L M N O P Q R S T U V W X Y Z");

    return 0;
}

输入样例

THE QUICK BROWN FOX JUMPED OVER THE LAZY DOG.
THIS IS AN EXAMPLE TO TEST FOR YOUR
HISTOGRAM PROGRAM.
HELLO!
[EOF]

输出样例

输出样例练习2

练习3

#include <string>
#include <iostream>
#include <cctype>
using namespace std;

void print(int p1, int p2, int p3, char front, char back) {
    if(back >= front) {
        printf("-");
        return;
    }

    if(p3 == 1) {
        for(int i = front; i < back; i++) {
            for(int j = p2; j > 0; j--) printf("%c", )
        }
    }
}

int main() {
    int p1, p2, p3;
    cin >> p1 >> p2 >> p3;

    string s;
    cin >> s;
    string::iterator it = s.begin();
    for(; it != s.end(); it++) {
        if(*it == '-') print(p1, p2, p3, *(it - 1), *(it + 1)); else printf("%c", *it);
    }

    return 0;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

[华为机试练习题]54.判断任意两台计算机的IP地址是否属于同一子网络

题目描述: 子网掩码是用来判断任意两台计算机的IP地址是否属于同一子网络的根据。 最为简单的理解就是两台计算机各自的IP地址与子网掩码进行AND运算后,如果得出的结果是相同的,则说明这两台计算...

http://www.cnblogs.com/freeliver54/p/3725979.html

写在前面 服务号和订阅号 URL配置 创建菜单 查询、删除菜单 接受消息 发送消息(图文、菜单事件响应) 示例Demo下载 后记   最近公司在做微信开发,其实就是接口开发,网上找了很多资料,当然...

疯狂Android讲义——P54-55丰富的表格视图(实现)

疯狂Android讲义——P54-55实现实现截图TIPS 组件格式 或者<> 代码块 <android.support.constraint.ConstraintLayout xmlns...

【win32程序控制台】练习题:堆栈数据增删过程的演示(来自c++primer plus p328~330)

/ * 程序的版权和版本声明部分 * Copyright (c) 2012, 华南师范大学软件工程专业 * All rights reserved. * 文件名称:堆栈数据增删过程...
  • Hookc
  • Hookc
  • 2012-04-10 13:12
  • 752

常用坐标系和投影分析,GIS的核心基础-地球坐标系与投影方式的理解(关于北京54,西安80,WGS84;高斯,兰勃特,墨卡托投影)

一、地球模型 地球是一个近似椭球体,测绘时用椭球模型逼近,这个模型叫做参考椭球,如下图: 赤道是一个半径为a的近似圆,任一圈经线是一个半径为b的近似圆。a称为椭球的长轴半径,b称为椭球的短...

JAVA_SE基础——54.异常

异常的体系: ----------| Throwable  所以异常或者错误类的超类 --------------|Error  错误   错误一般是用于jvm或者是硬件引发的问题,所以我们一般不会通...

C++primer 第五版 练习题【3.32】 P104页 个人解答

#include #include #include using namespace std; int main(){ vector ivec1; vector ivec2; for(int i...

day54_电力项目_webservice改造&报表导出基础

项目第七天(webservice+二级缓存+导出设置)1:使用webservice发布系统元数据,分公司调用的过程(axis2)需求: 操作步骤:详情请看【技术资料\webservice远程技术\a...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)