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

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

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语言初阶已经有了一个整体的概念,但我们只知道一些理论上的知识还是没有用的,所以今天我在网上找了一些题目给大家练习巩固之前学的知识,这样能更好的帮助我们加深对其的理解。
242 0
|
3月前
|
C语言
【C语言的完结】:最后的测试题
【C语言的完结】:最后的测试题
25 3
|
8月前
|
存储 安全 编译器
【C++初阶】10 .习题①
【C++初阶】10 .习题①
71 2
|
8月前
|
C语言
C语言:初阶测试错题(查漏补缺)
C语言:初阶测试错题(查漏补缺)
49 0
|
C语言
让C语言的调试更加高大上
让C语言的调试更加高大上
85 1
让C语言的调试更加高大上
|
机器学习/深度学习 C语言
C语言期末程序复习基础题(二)
C语言期末程序复习基础题(二)
|
程序员 C语言
【维生素C语言】第八章 - 实用调试技巧(四)
一名优秀的程序员是一名出色的侦探,每一次调试都是尝试破案的过程……本章将详细带你学习实用调试技巧!正式开启DEBUG
87 1
【维生素C语言】第八章 - 实用调试技巧(四)
|
C语言
c语言实现三子棋(内含阅读思路,简单易实现)
本文如果按顺序来阅读可能不太好接受,建议阅读顺序为,由test.c的逻辑顺序读下去,遇见具体函数的实现跳转到game.c中来理解
153 0
c语言实现三子棋(内含阅读思路,简单易实现)
|
程序员 编译器 C语言
【维生素C语言】第八章 - 实用调试技巧(三)
一名优秀的程序员是一名出色的侦探,每一次调试都是尝试破案的过程……本章将详细带你学习实用调试技巧!正式开启DEBUG
94 0
【维生素C语言】第八章 - 实用调试技巧(三)
|
程序员 测试技术 C语言
【维生素C语言】第八章 - 实用调试技巧(一)
一名优秀的程序员是一名出色的侦探,每一次调试都是尝试破案的过程……本章将详细带你学习实用调试技巧!正式开启DEBUG
103 0
【维生素C语言】第八章 - 实用调试技巧(一)

热门文章

最新文章