图论一课(2)

本文详细介绍了浮点数的存储方式及其在内存中的表示形式,并解释了不同类型的运算符工作原理,包括逻辑运算符、位运算符等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

课堂


1.浮点数
浮点类型分为float(单精度),double(双精度),如果定义一个变量float a = 12.5f;内存会分配四个字节给变量a,在内存中的表示形式为:1位符号位,8位阶码(指数),23位尾数。
float
- 将12.5转化为二进制为1100.1,科学指数法为1.1001*2^3,其中1001是尾数,3为指数。
- 首先,符号位肯定为0;
- 其次来看指数部分,由于指数部分可能为负数,在这里需要让指数3加上127存放到阶码的8位里。
- 对于尾数,就把1001放在小数点后,然后后面补0,因为尾数加0不改变尾数的值。
注:
- 指数的取值范围为:-127 -> 128,如果除去指数为0和1时,则是-126 ->127;
- 尾数的精度:6位,根据尾数的位数得2^23 = 8388608,则最多可表示6为有效数字。

2.内存存储方式
- 小端存储——低地址存入低数据(PC,inter)
- 大端存储——低地址存入高数据(网络,手机)
例:小端存储——

     int a = 10;
     printf("%d\n",a);

小端存储

3.运算符
(1)++i / i++
j = i++;会生成辅助内存空间,操作步骤为:(tmp) = i; j = (tmp); i = i+1;
j = ++i;则不会浪费空间,其操作步骤为:i = i+1; j = i;

(2)&& / || / !
1)逻辑与(&&):必须表达式全为真
注:if (表1 && 表2 && 表3) 时,若表1为假则只执行表1,否则继续表2,若表2也为假则执行表1和表2,否则继续表3……

     int a = 0,b = 1,c = 2;
     if (a++ && b++ && c++)
     {
          printf("ture:%d %d %d\n",a,b,c);
     }
     else
     {
          printf("false:%d %d %d\n,a,b,c");
     }

&&

2)逻辑或(||):只要一个表达式为真
注:if (表1 || 表2 || 表3) 时,若表1为真则只执行表1,否则继续表2,若表2也为真则执行表1和表2,否则继续表3……

     int a = 0,b = 1,c = 2;
     if (a++ || b++ || c++)
     {
          printf("ture:%d %d %d\n",a,b,c);
     }
     else
     {
          printf("false:%d %d %d\n,a,b,c");
     }

||

3)逻辑非(!):非真为假,非假为真

int a = 10;
a = !!a;
printf(" %d\n",a);
if (a == 1)printf("turn\n");else printf("false\n");
if (a != 1)printf("turn\n");else printf("false\n");
if (a == 0)printf("false\n");else printf("true\n");
if (a != 0)printf("turn\n");else printf("false\n");

!

(3)~ / | / & / ^ / >> / <<

10:0000 1010
11:0000 1011

1)按位取反~:~10: 1111 0101
2)按位取或 |:10 | 11:0000 1011
3)按位取与 &:10 & 11:0000 1010
4)按位异或 ^:10 ^ 11:0000 0001
5)右移>>:10 >> 1:0000 0101 -> 5
6)左移<<:10 << 1:0001 0100 -> 20

(4)* / &
int a = 10;
int *p = &a ;
*p = 20;//解引用,跳入内存

内容概要:本文深入解析了扣子COZE AI编程及其详细应用代码案例,旨在帮助读者理解新代低门槛智能体开发范式。文章从五个维度展开:关键概念、核心技巧、典型应用场景、详细代码案例分析以及未来发展趋势。首先介绍了扣子COZE的核心概念,如Bot、Workflow、Plugin、Memory和Knowledge。接着分享了意图识别、函数调用链、动态Prompt、渐进式发布及监控可观测等核心技巧。然后列举了企业内部智能客服、电商导购助手、教育领域AI助教和金融行业合规质检等应用场景。最后,通过构建“会议纪要智能助手”的详细代码案例,展示了从需求描述、技术方案、Workflow节点拆解到调试与上线的全过程,并展望了多智能体协作、本地私有部署、Agent2Agent协议、边缘计算插件和实时RAG等未来发展方向。; 适合人群:对AI编程感兴趣的开发者,尤其是希望快速落地AI产品的技术人员。; 使用场景及目标:①学习如何使用扣子COZE构建生产级智能体;②掌握智能体实例、自动化流程、扩展能力和知识库的使用方法;③通过实际案例理解如何实现会议纪要智能助手的功能,包括触发器设置、下载节点、LLM节点Prompt设计、Code节点处理和邮件节点配置。; 阅读建议:本文不仅提供了理论知识,还包含了详细的代码案例,建议读者结合实际业务需求进行实践,逐步掌握扣子COZE的各项功能,并关注其未来的发展趋势。
选修系统可以使用图论知识建模为张有向图,其中每个节点表示个选修,每条边表示个选修的先修程关系。这样,我们就可以使用图论算法来帮助学生选择合适的选修。 以下是使用图论知识建模选修系统的具体步骤: 1. 将选修之间的先修关系表示为有向边。例如,如果选修A需要先修选修B,那么我们就在B和A之间连条有向边。 2. 将每个选修的基本信息作为节点的属性保存。例如,每个节点可以包含以下属性:选修名称、选修编号、教师姓名、学分等信息。 3. 使用图论算法帮助学生选择合适的选修。例如,可以使用拓扑排序算法来检测图中是否存在环,以确保学生选择的选修程之间不存在先修程冲突。同时,还可以使用最短路径算法来帮助学生选择最优的选修组合,以满足学位要求和个人兴趣。 以下是使用python实现选修系统的示例代码: ```python class Course: def __init__(self, name, id, teacher, credit): self.name = name self.id = id self.teacher = teacher self.credit = credit self.pre_courses = [] # 先修程列表 def add_pre_course(self, course): self.pre_courses.append(course) class CourseSelectionSystem: def __init__(self): self.courses = {} # 选修列表 def add_course(self, course): self.courses[course.id] = course def add_pre_course(self, course_id, pre_course_id): course = self.courses[course_id] pre_course = self.courses[pre_course_id] course.add_pre_course(pre_course) def is_course_valid(self, course_id, selected_courses): """ 检查选修是否合法 :param course_id: 选修ID :param selected_courses: 已选修列表 :return: 是否合法 """ course = self.courses[course_id] for pre_course in course.pre_courses: if pre_course.id not in selected_courses: return False return True def get_valid_courses(self, selected_courses): """ 获取合法的选修列表 :param selected_courses: 已选修列表 :return: 合法的选修列表 """ valid_courses = [] for course_id in self.courses: if course_id not in selected_courses and self.is_course_valid(course_id, selected_courses): valid_courses.append(self.courses[course_id]) return valid_courses def get_shortest_path(self, start_course_id, end_course_id): """ 获取两个选修之间的最短路径 :param start_course_id: 起始选修ID :param end_course_id: 终止选修ID :return: 最短路径 """ graph = {} # 选修之间的有向图 for course_id in self.courses: graph[course_id] = [(pre_course.id, 1) for pre_course in self.courses[course_id].pre_courses] length, path = dijkstra(graph, start_course_id, end_course_id) return [self.courses[course_id] for course_id in path] # 示例代码 course_sys = CourseSelectionSystem() # 添加选修 course_sys.add_course(Course('计算机网络', 'C001', '张三', 3)) course_sys.add_course(Course('操作系统', 'C002', '李四', 4)) course_sys.add_course(Course('数据库系统', 'C003', '王五', 3)) course_sys.add_course(Course('算法设计与分析', 'C004', '赵六', 4)) course_sys.add_course(Course('编译原理', 'C005', '钱七', 3)) # 设置选修之间的先修关系 course_sys.add_pre_course('C001', 'C002') course_sys.add_pre_course('C001', 'C003') course_sys.add_pre_course('C002', 'C004') course_sys.add_pre_course('C003', 'C004') course_sys.add_pre_course('C004', 'C005') # 获取合法的选修列表 valid_courses = course_sys.get_valid_courses(['C001', 'C002']) print('合法的选修列表:', [course.name for course in valid_courses]) # 获取最短路径 path = course_sys.get_shortest_path('C001', 'C005') print('最短路径:', [course.name for course in path]) ``` 在上述代码中,我们定义了个Course类来保存选修的基本信息,另外定义了个CourseSelectionSystem类来实现选修系统。在该系统中,我们使用字典来保存选修列表,其中每个选修都是个节点,节点之间的先修关系用有向边表示。我们还实现了is_course_valid和get_valid_courses方法来检测选修组合是否合法,实现了get_shortest_path方法来获取两个选修之间的最短路径。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值