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

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

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语言】练习题整理:11
【C语言】练习题整理:11
132 1
|
存储 人工智能 编译器
【C语言】练习题整理:12
【C语言】练习题整理:12
114 0
|
人工智能 算法 测试技术
【C语言】初阶完结练习题
C语言初阶知识点已经全部更完,相信大家对C语言初阶已经有了一个整体的概念,但我们只知道一些理论上的知识还是没有用的,所以今天我在网上找了一些题目给大家练习巩固之前学的知识,这样能更好的帮助我们加深对其的理解。
224 0
|
6月前
|
存储 算法 C语言
C语言初学者超详细习题库1(含题目以及代码讲解)
C语言初学者超详细习题库1(含题目以及代码讲解)
87 1
|
程序员 编译器 C语言
【初阶C语言】实用调试技巧(详细介绍)(二)
【初阶C语言】实用调试技巧(详细介绍)(二)
【初阶C语言】实用调试技巧(详细介绍)(二)
|
NoSQL 程序员 编译器
【初阶C语言】实用调试技巧(详细介绍)(一)
【初阶C语言】实用调试技巧(详细介绍)(一)
【初阶C语言】实用调试技巧(详细介绍)(三)
【初阶C语言】实用调试技巧(详细介绍)(三)
|
程序员 编译器 C语言
初阶C语言 第二章-------《函数》知识点(自定义函数,库函数,函数递归)+思维导图+基本练习题+超详细+通俗易懂(建议收藏)
初阶C语言 第二章-------《函数》知识点(自定义函数,库函数,函数递归)+思维导图+基本练习题+超详细+通俗易懂(建议收藏)
|
C语言
明解C语言第一章习题
明解C语言第一章习题
明解C语言第一章习题
|
存储 编译器 vr&ar
C语言进阶第四篇【指针习题详解】(上)
C语言进阶第四篇【指针习题详解】(上)
101 0
C语言进阶第四篇【指针习题详解】(上)