实用调试技巧(初阶)习题

简介: 实用调试技巧(初阶)习题

1 知识点

(1)const int*p;const修饰的是 *p ; const int *p与int const *p等价

(2)Debug为调试版本,一般在开发完成后发布工程前,调试代码都是在Debug模式下进行的;Release版本最终是要发送给用户的,发给用户的版本必须要没有问题,测试人员就是最后一个把关的;Debug版本是调试版本,编译器编译时会增加一些调试信息,编译器基本不会对其进行优化Release版本不能调试,一般都是在Debug版本下调试的,Release版本一般编译器会进行大量的优化,删除无用的代码,指令的次序调整等,让其速度更快。

2 调整数组使奇数全部都位于偶数前面。

输入一个整数数组,实现一个函数, 来调整该数组中数字的顺序使得数组中所有的奇数位于数组的前半部分,所有偶数位于数组的后半部分。

代码展示:

1. #include <stdio.h>
2. void print(int arr[], int len)
3. {
4.  int i = 0;
5.  for (i = 0; i < len; i++)
6.  {
7.    printf("%d ", arr[i]);
8.  }
9.  printf("\n");
10. }
11. void move(int arr[], int len)
12. {
13.   int* left = arr;
14.   int* right = arr + len - 1;
15.   while (left < right)
16.   {
17.     while ((*left) % 2 == 1)
18.     {
19.       left++;
20.     }
21.     while ((*right) % 2 == 0)
22.     {
23.       right--;
24.     }
25.     if (left < right)
26.     {
27.       int ret = 0;
28.       ret = *left;
29.       *left = *right;
30.       *right = ret;
31.     }
32.   }
33. }
34. int main()
35. {
36.   int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
37.   int sz = sizeof(arr) / sizeof(arr[0]);
38.   move(arr, sz);
39.   print(arr, sz);
40.   return 0;
41. }

思路:

在前面找到偶数,与在后面找到的奇数换一下位置。

(1)从左向右找一个偶数(2)从右向左找一个奇数(3)进行交换

注意:当left小于right的时候,进入循环,可能找到的left和right不是left小于right的,如果此时直接交换会发生错误,所以交换的时候,要加上一个判断条件。

代码优化:

如果数组里面出现都是奇数或者都是偶数,那么就会发生while循环越界,所以while要有一个条件。

1. #include <stdio.h>
2. void print(int arr[], int len)
3. {
4.  int i = 0;
5.  for (i = 0; i < len; i++)
6.  {
7.    printf("%d ", arr[i]);
8.  }
9.  printf("\n");
10. }
11. void move(int arr[], int len)
12. {
13.   int* left = arr;
14.   int* right = arr + len - 1;
15.   while (left < right)
16.   {
17.     while ((left < right) && (*left) % 2 == 1)
18.     {
19.       left++;
20.     }
21.     while ((left < right) && (*right) % 2 == 0)
22.     {
23.       right--;
24.     }
25.     if (left < right)
26.     {
27.       int ret = 0;
28.       ret = *left;
29.       *left = *right;
30.       *right = ret;
31.     }
32.   }
33. }
34. int main()
35. {
36.   int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
37.   int sz = sizeof(arr) / sizeof(arr[0]);
38.   move(arr, sz);
39.   print(arr, sz);
40.   return 0;
41. }

注意:打印一串字符串,可以返回数组名。 打印其他类型,要用for循环,一个一个打印

相关文章
|
3天前
|
数据采集 人工智能 安全
|
12天前
|
云安全 监控 安全
|
4天前
|
自然语言处理 API
万相 Wan2.6 全新升级发布!人人都能当导演的时代来了
通义万相2.6全新升级,支持文生图、图生视频、文生视频,打造电影级创作体验。智能分镜、角色扮演、音画同步,让创意一键成片,大众也能轻松制作高质量短视频。
1063 151
|
4天前
|
编解码 人工智能 机器人
通义万相2.6,模型使用指南
智能分镜 | 多镜头叙事 | 支持15秒视频生成 | 高品质声音生成 | 多人稳定对话
|
17天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1739 9
|
9天前
|
人工智能 自然语言处理 API
一句话生成拓扑图!AI+Draw.io 封神开源组合,工具让你的效率爆炸
一句话生成拓扑图!next-ai-draw-io 结合 AI 与 Draw.io,通过自然语言秒出架构图,支持私有部署、免费大模型接口,彻底解放生产力,绘图效率直接爆炸。
685 152
|
11天前
|
人工智能 安全 前端开发
AgentScope Java v1.0 发布,让 Java 开发者轻松构建企业级 Agentic 应用
AgentScope 重磅发布 Java 版本,拥抱企业开发主流技术栈。
653 12
|
6天前
|
SQL 自然语言处理 调度
Agent Skills 的一次工程实践
**本文采用 Agent Skills 实现整体智能体**,开发框架采用 AgentScope,模型使用 **qwen3-max**。Agent Skills 是 Anthropic 新推出的一种有别于mcp server的一种开发方式,用于为 AI **引入可共享的专业技能**。经验封装到**可发现、可复用的能力单元**中,每个技能以文件夹形式存在,包含特定任务的指导性说明(SKILL.md 文件)、脚本代码和资源等 。大模型可以根据需要动态加载这些技能,从而扩展自身的功能。目前不少国内外的一些框架也开始支持此种的开发方式,详细介绍如下。
413 4