C/C++常用数据类型梳理

C/C++常用数据类型梳理

常用数据类型

数据类型占用字节数取值范围
short2-32,768 ~~ 32,767
-215~~215-1
int4-2,147,483,648 ~~ 2,147,483,647
-231~231-1
long4-2,147,483,648 ~~ 2,147,483,647
-231~231-1
long long8-9,223,372,036,854,775,808 ~~ 9,223,372,036,854,775,807
-263 ~~ 263-1
float41.17549e-038 ~~ 3.40282e+038
double82.22507e-308 ~~ 1.79769e+308
bool10 ~~ 1
char1-128 ~~ 127
-28 ~~ 28-1

代码实现

附一段C++代码:

#include<iostream>
#include<iomanip>
#include<limits>
using namespace std;
int main(){
    cout<<" ==================================================================="<<endl;
    cout<<"| 数据类型 |占用字节数|       最小取值       |       最大取值       |"<<endl;
    cout<<" -------------------------------------------------------------------"<<endl;
    cout<<"|short     |"<<left<<setw(10)<<sizeof(short)<<"|"<<
		setw(22)<<(numeric_limits<short>::min)()<<"|"<<
		setw(22)<<(numeric_limits<short>::max)()<<"|"<<endl;
	cout<<" -------------------------------------------------------------------"<<endl;
    cout<<"|int       |"<<left<<setw(10)<<sizeof(int)<<"|"<<
		setw(22)<<(numeric_limits<int>::min)()<<"|"<<
		setw(22)<<(numeric_limits<int>::max)()<<"|"<<endl;
	cout<<" -------------------------------------------------------------------"<<endl;
    cout<<"|long      |"<<left<<setw(10)<<sizeof(long)<<"|"<<
		setw(22)<<(numeric_limits<long>::min)()<<"|"<<
		setw(22)<<(numeric_limits<long>::max)()<<"|"<<endl;
	cout<<" -------------------------------------------------------------------"<<endl;
    cout<<"|long long |"<<left<<setw(10)<<sizeof(long long)<<"|"<<
		setw(22)<<(numeric_limits<long long>::min)()<<"|"<<
		setw(22)<<(numeric_limits<long long>::max)()<<"|"<<endl;
	cout<<" -------------------------------------------------------------------"<<endl;
    cout<<"|float     |"<<left<<setw(10)<<sizeof(float)<<"|"<<
		setw(22)<<(numeric_limits<float>::min)()<<"|"<<
		setw(22)<<(numeric_limits<float>::max)()<<"|"<<endl;
	cout<<" -------------------------------------------------------------------"<<endl;
    cout<<"|double    |"<<left<<setw(10)<<sizeof(double)<<"|"<<
		setw(22)<<(numeric_limits<double>::min)()<<"|"<<
		setw(22)<<(numeric_limits<double>::max)()<<"|"<<endl;
	cout<<" -------------------------------------------------------------------"<<endl;
	cout<<"|bool      |"<<left<<setw(10)<<sizeof(bool)<<"|"<<
		setw(22)<<(numeric_limits<bool>::min)()<<"|"<<
		setw(22)<<(numeric_limits<bool>::max)()<<"|"<<endl;
	cout<<" -------------------------------------------------------------------"<<endl;
	cout<<"|char      |"<<left<<setw(10)<<sizeof(char)<<"|"<<
		setw(22)<<(int)(numeric_limits<char>::min)()<<"|"<<
		setw(22)<<(int)(numeric_limits<char>::max)()<<"|"<<endl;
	cout<<" -------------------------------------------------------------------"<<endl;
    return 0;
}

运行结果:
在这里插入图片描述
根据上述代码,可自行测试其他的数据类型。

1.关于int类型与long类型的占用字节数、取值范围相同:
      之所以有“整型”和“长整形”两种不同类型,是C语言在诞生时发明者规定好的,前者存储的整数的值域小于后者。
      早期的操作系统是16位系统,int用二字节表示,范围是-32768 ~ 32767;long用4字节表示,范围是-2147483648 ~ 2147483647。
      后来发展到32位操作系统,int 用4字节表示,与long相同。
      目前的操作系统已发展到64位操作系统,但因程序编译工艺的不同,两者表现出不同的差别:
32位编译系统:int占四字节,与long相同。
64位编译系统:int占四字节,long占8字节,long数据范围变为:-263~263-1

2.如何表示各种数据类型的最大值?
      利用limits.h库。表示最大值为TYPE_MAX,最小值为TYPE_MIN。(没有提供浮点数)
      如:

#include <stdio.h>
#include <limits.h>
int main(){
   printf("The number of bits in a byte %d\n", CHAR_BIT);
   printf("The minimum value of SIGNED CHAR = %d\n", SCHAR_MIN);
   printf("The maximum value of SIGNED CHAR = %d\n", SCHAR_MAX);
   printf("The maximum value of UNSIGNED CHAR = %d\n", UCHAR_MAX);
   printf("The minimum value of SHORT INT = %d\n", SHRT_MIN);
   printf("The maximum value of SHORT INT = %d\n", SHRT_MAX); 
   printf("The minimum value of INT = %d\n", INT_MIN);
   printf("The maximum value of INT = %d\n", INT_MAX);
   printf("The minimum value of CHAR = %d\n", CHAR_MIN);
   printf("The maximum value of CHAR = %d\n", CHAR_MAX);
   printf("The minimum value of LONG = %ld\n", LONG_MIN);
   printf("The maximum value of LONG = %ld\n", LONG_MAX);  
   return(0);
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: C/C++算法常用手册是程序员日常工作中不可或缺的工具书之一。该手册主要收录了程序员在开发过程中常用的算法,以及相应的代码实现。该手册涵盖了诸如数据结构、排序、查找、递归、贪心、动态规划、字符串等算法,帮助程序员快速掌握这些算法的基本原理和实现方式。简单地说,该手册将算法的核心原理和实现细节集中在了一起,兼顾了易懂性和实用性。 随着程序员需求的不断增加,该手册逐渐扩充了更多的算法类型。同时,该手册还根据算法的不同应用场景进行分类,方便程序员快速查找和使用。例如,程序员可以通过该手册快速了解不同数据结构的原理和实现方法,了解常见算法的时间复杂度和空间复杂度,还可以查找常见的实际问题中的算法实现方式。 总的来说,C/C++算法常用手册是程序员必备的工具之一,帮助程序员提高算法的实现能力和解决实际问题的能力,提高程序的效率和质量。 ### 回答2: C/C++常用算法手册是一本介绍计算机算法的参考手册,主要面向C/C++语言程序员。该手册总结了各种常用的算法,包括排序、查找、图论、字符串等。通过该手册的学习,可以让程序员更好地掌握C/C++编程的技巧和方法。 该手册中介绍了排序算法,包括冒泡排序、插入排序、选择排序、快速排序、归并排序等。对于不同的排序算法,手册详细介绍了它们的思路和实现方法,同时也对它们的时间复杂度和效率进行了分析和比较。 在查找方面,手册介绍了常用的顺序查找和二分查找算法,它们可以帮助程序员快速地定位和查找数据。 在图论和字符串方面,手册介绍了很多有用的算法,如最短路径算法、最小生成树算法、字符串匹配算法等。这些算法可以帮助程序员更好地解决实际问题。 总之,C/C++常用算法手册是一本非常实用和有价值的参考书,它可以让程序员掌握更多的C/C++算法技巧,提高程序员的编程能力和开发效率。 ### 回答3: C/C++ 常用算法手册是一本总结了 C/C++ 编程语言中常用的算法、数据结构、设计模式等知识的参考书籍。 相对于其他语言,C 和 C++ 语言有着更高的执行效率和更多的编程自由度,也因此被广泛应用于开发高性能、底层的软件程序。在这样的应用场景下,对算法和数据结构的掌握显得尤为重要。 C/C++ 常用算法手册涵盖了各种基础的算法和数据结构,比如排序、查找、链表、树等。同时,它也介绍了一些常用的高级算法,比如动态规划、贪心算法和回溯算法。 此外,该手册还详细说明了面向对象编程领域中常用的设计模式和其实现方式,例如工厂模式、装饰器模式等。 阅读 C/C++ 常用算法手册不但能够让读者掌握常用算法的实现方法,更能提高编程思维和技巧。另外,在实际应用中,编写高效的程序不仅需要算法的巧妙运用,更需要细致、严谨的代码风格和设计思路。此时,该手册中丰富的示例代码和编码规范性的讲解也能为读者提供很大的帮助。 总之,C/C++ 常用算法手册是一本既实用又深入的参考书,适合广大 C/C++ 开发者和算法学习者阅读。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值