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

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

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循环,一个一个打印

相关文章
|
人工智能 算法 测试技术
【C语言】初阶完结练习题
C语言初阶知识点已经全部更完,相信大家对C语言初阶已经有了一个整体的概念,但我们只知道一些理论上的知识还是没有用的,所以今天我在网上找了一些题目给大家练习巩固之前学的知识,这样能更好的帮助我们加深对其的理解。
247 0
|
算法 C语言 数据安全/隐私保护
C语言及算法设计课程实验三:最简单的C程序设计——顺序程序设计(四)
C语言及算法设计课程实验三:最简单的C程序设计——顺序程序设计(四)
C语言及算法设计课程实验三:最简单的C程序设计——顺序程序设计(四)
|
1月前
|
算法 C语言
【C语言程序设计——循环程序设计】求解最大公约数(头歌实践教学平台习题)【合集】
采用欧几里得算法(EuclideanAlgorithm)求解两个正整数的最大公约数。的最大公约数,然后检查最大公约数是否大于1。如果是,就返回1,表示。根据提示,在右侧编辑器Begin--End之间的区域内补充必要的代码。作为新的参数传递进去。这个递归过程会不断进行,直到。有除1以外的公约数;变为0,此时就找到了最大公约数。开始你的任务吧,祝你成功!是否为0,如果是,那么。就是最大公约数,直接返回。
77 18
|
7月前
递推 7-1 sdut-C语言实验-母牛的故事
递推 7-1 sdut-C语言实验-母牛的故事
39 0
|
9月前
|
存储 C语言
C语言初阶④(数组)知识点+编程作业(三子棋,冒泡排序)(下)
C语言初阶④(数组)知识点+编程作业(三子棋,冒泡排序)
49 1
|
9月前
|
存储 C语言
C语言初阶④(数组)知识点+编程作业(三子棋,冒泡排序)(上)
C语言初阶④(数组)知识点+编程作业(三子棋,冒泡排序)
48 0
|
9月前
|
存储 安全 编译器
【C++初阶】10 .习题①
【C++初阶】10 .习题①
74 2
|
9月前
|
C语言
C语言:初阶测试错题(查漏补缺)
C语言:初阶测试错题(查漏补缺)
52 0
|
程序员 编译器 C语言
【初阶C语言】实用调试技巧(详细介绍)(二)
【初阶C语言】实用调试技巧(详细介绍)(二)
【初阶C语言】实用调试技巧(详细介绍)(二)
|
存储 算法 C语言
[数据结构与算法(严蔚敏 C语言第二版)]第1章 绪论(课后习题+答案解析)
[数据结构与算法(严蔚敏 C语言第二版)]第1章 绪论(课后习题+答案解析)