C++系列-第1章顺序结构-9-字符类型char

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介: C++系列-第1章顺序结构-9-字符类型char

在线练习:

http://noi.openjudge.cn/

https://www.luogu.com.cn/

总结

本文是C++系列博客,主要讲述字符类型char

字符类型char

在C++编程语言中,char是一种基本的数据类型,它用于存储单个字符。字符可以是字母、数字、标点符号或者是转义字符等。char类型通常占用一个字节(byte)的内存空间。

一个字节表示八位二进制数,8位无符号的二进制数可以表示为00000000-11111111,即0-255。

二进制是计算技术中广泛采用的一种数制。二进制数据是用0和1两个数码来表示的数。它的基数为2,进位规则是“逢二进一”,借位规则是“借一当二”。

二进制转十进制:要从右到左用二进制的每个数去乘以2的相应次方

二进制的11111111=127+1*26+125+……1*20=128+64+32+16+8+4+2+1=255

所以一个字节表示无符号整数可以表示十进制的0-255共256个数,最大值为255。

基础知识

  1. 声明:声明一个char类型的变量,你可以这样做:
char myChar = 'A';
  1. 在这里,myChar是一个char类型的变量,并且它被赋予了字符A
  2. 字符表示:字符值需要用单引号(’ ')包围,比如'a''1''#'
  3. ASCII值:每个char类型的字符都对应一个ASCII码值。例如,字符'A'的ASCII码值是65。

案例:字符转换

下面是一个简单的案例,它演示了如何将小写字母转换为大写字母。这个程序会提示用户输入一个小写字母,然后程序将其转换为大写字母并显示结果。

#include <iostream>
using namespace std;
int main() {
    char lowercase, uppercase;
    cout << "请输入一个小写字母: ";
    cin >> lowercase;
    // 将小写字母转换为ASCII码值,然后减去32得到大写字母的ASCII码值
    uppercase = lowercase - 32;
    cout << "大写字母是: " << uppercase << endl;
    return 0;
}

输出为:

练习案例:字符判断

现在,你可以尝试一个练习案例。编写一个程序,让用户输入一个字符,然后判断它是大写字母、小写字母还是数字。

提示:

  • 大写字母的ASCII码范围是65到90。
  • 小写字母的ASCII码范围是97到122。
  • 数字字符的ASCII码范围是48到57。
    你可以在下面的代码框架中填充代码:
#include <iostream>
using namespace std;
int main() {
    char inputChar;
    cout << "请输入一个字符: ";
    cin >> inputChar;
    // 判断输入的字符类型
    if ((inputChar >= 'A') && (inputChar <= 'Z')) {
        cout << "你输入的是一个大写字母。" << endl;
    } else if ((inputChar >= 'a') && (inputChar <= 'z')) {
        cout << "你输入的是一个小写字母。" << endl;
    } else if ((inputChar >= '0') && (inputChar <= '9')) {
        cout << "你输入的是一个数字。" << endl;
    } else {
        cout << "你输入的字符不是字母也不是数字。" << endl;
    }
    return 0;
}

输出为:

案例 输出字符的ASCII值

#include <iostream>
using namespace std;
int main() {
    char myChar = 'A'; // 声明一个char类型的变量并初始化为'A'
    // 打印字符
    cout << "字符: " << myChar << endl;
    // 打印字符的ASCII码值
    cout << "ASCII码值: " << int(myChar) << endl;
    return 0;
}

输出为:

案例加密和解密简化版

下面是一个基本的例子,它演示了如何对单个字符进行加密和解密:

#include <iostream>
using namespace std;
int main() {
    char plainChar;
    int shift;
    cout << "请输入一个要加密的字符: ";
    cin >> plainChar; // 输入一个字符
    cout << "请输入加密的偏移量 (1-25): ";
    cin >> shift;
    // 加密字符
    char encryptedChar = plainChar + shift;
    cout << "加密后的字符: " << encryptedChar << endl;
    // 解密字符
    char decryptedChar = encryptedChar - shift;
    cout << "解密后的字符: " << decryptedChar << endl;
    return 0;
}

输出为:

在这个程序中,我们首先提示用户输入一个要加密的字符和一个整数偏移量(范围是1-25)。然后,我们通过将字符的ASCII码值加上偏移量来得到加密后的字符,并打印出来。接着,我们通过从加密后的字符的ASCII码值中减去相同的偏移量来得到解密后的字符,并打印出来。

请注意,这个程序只能处理一个字符,并且没有考虑加密过程中可能出现的边界情况,例如字符是大写字母、小写字母还是其他特殊字符。在实际应用中,加密通常会使用更复杂的算法和安全的密钥。

案例 加密和解密函数

下面是一个基于char和ASCII的简单加密案例。这个程序会将用户输入的文本进行加密,然后将加密后的文本输出。加密过程将使用一个简单的算法,例如对每个字符的ASCII码值进行加法操作。

#include <iostream>
#include <string>
using namespace std;
string encrypt(string text, int shift) {
    string encryptedText = "";
    for (int i = 0; i < text.length(); i++) {
        // 对每个字符的ASCII码值进行加法操作
        char encryptedChar = text[i] + shift;
        // 将加密后的字符添加到加密文本中
        encryptedText += encryptedChar;
    }
    return encryptedText;
}
string decrypt(string encryptedText, int shift) {
    string decryptedText = "";
    for (int i = 0; i < encryptedText.length(); i++) {
        // 对每个字符的ASCII码值进行减法操作以解密
        char decryptedChar = encryptedText[i] - shift;
        // 将解密后的字符添加到解密文本中
        decryptedText += decryptedChar;
    }
    return decryptedText;
}
int main() {
    string text;
    int shift;
    cout << "请输入要加密的文本: ";
    getline(cin, text); // 使用getline来允许输入空格
    cout << "请输入加密的偏移量: ";
    cin >> shift;
    string encryptedText = encrypt(text, shift);
    cout << "加密后的文本: " << encryptedText << endl;
    string decryptedText = decrypt(encryptedText, shift);
    cout << "解密后的文本: " << decryptedText << endl;
    return 0;
}

输出为:

在这个程序中,我们定义了两个函数encryptdecrypt来分别处理加密和解密操作。加密函数通过将每个字符的ASCII码值加上一个偏移量来实现加密,而解密函数则通过从加密后的ASCII码值中减去相同的偏移量来实现解密。

main函数中,我们首先提示用户输入要加密的文本和一个整数偏移量。然后,我们调用encrypt函数来加密文本,并打印出加密后的结果。接着,我们调用decrypt函数来解密文本,并打印出解密后的结果。

请注意,这个加密算法非常简单,并不适合真正的安全加密需求。在实际应用中,加密通常会使用更复杂的算法和安全的密钥。

相关文章
|
2月前
|
SQL 存储 关系型数据库
SQL判断CHAR类型字段不为空的方法与技巧
在SQL查询中,判断一个CHAR类型字段是否不为空是一个常见的需求
|
3月前
|
存储 Java Windows
java基础(9)数据类型中的char类型以及涉及到的转义字符
Java中的char类型可以存储一个中文字符,因为它占用两个字节。转义字符允许在代码中使用特殊字符,例如`\n`表示换行,`\t`表示制表符,`\\`表示反斜杠,`\'`表示单引号,`\"`表示双引号。可以使用`\u`后跟Unicode编码来表示特定的字符。
60 2
java基础(9)数据类型中的char类型以及涉及到的转义字符
|
2月前
|
存储 编译器 程序员
C++类型参数化
【10月更文挑战第1天】在 C++ 中,模板是实现类型参数化的主要工具,用于编写能处理多种数据类型的代码。模板分为函数模板和类模板。函数模板以 `template` 关键字定义,允许使用任意类型参数 `T`,并在调用时自动推导具体类型。类模板则定义泛型类,如动态数组,可在实例化时指定具体类型。模板还支持特化,为特定类型提供定制实现。模板在编译时实例化,需放置在头文件中以确保编译器可见。
33 11
|
3月前
|
C++
【C++基础】程序流程结构详解
这篇文章详细介绍了C++中程序流程的三种基本结构:顺序结构、选择结构和循环结构,包括if语句、三目运算符、switch语句、while循环、do…while循环、for循环以及跳转语句break、continue和goto的使用和示例。
54 2
|
3月前
|
安全 程序员 C语言
C++(四)类型强转
本文详细介绍了C++中的四种类型强制转换:`static_cast`、`reinterpret_cast`、`const_cast`和`dynamic_cast`。每种转换都有其特定用途和适用场景,如`static_cast`用于相关类型间的显式转换,`reinterpret_cast`用于低层内存布局操作,`const_cast`用于添加或移除`const`限定符,而`dynamic_cast`则用于运行时的类型检查和转换。通过具体示例展示了如何正确使用这四种转换操作符,帮助开发者更好地理解和掌握C++中的类型转换机制。
|
4月前
|
C++
使用 QML 类型系统注册 C++ 类型
使用 QML 类型系统注册 C++ 类型
62 0
|
4月前
|
存储 C++
【C/C++学习笔记】string 类型的输入操作符和 getline 函数分别如何处理空白字符
【C/C++学习笔记】string 类型的输入操作符和 getline 函数分别如何处理空白字符
44 0
|
4月前
|
C++
c++学习笔记03 程序流程结构
C++学习笔记,主要介绍了程序流程结构,包括顺序结构、选择结构和循环结构。选择结构中详细解释了if语句、三目运算符和switch语句的用法和注意事项。循环结构部分则涵盖了while循环、do-while循环和for循环的语法和使用技巧。此外,还介绍了跳转语句,包括break、continue和goto语句的用途和用法。
36 0
|
存储 关系型数据库 MySQL
面试时被这样一个问:”存储MD5值应该用VARCHAR还是用CHAR?
一个5年工作经验的小伙伴,在面试的时候被这样一个问题。说”存储MD5值应该用VARCHAR还是用CHAR“,他一时间不只如何选择,感觉用VARCHAR也可以,用CHAR也行。希望我来帮忙分析一下。
120 0
|
4月前
|
存储 数据管理 数据库