【C语言】分支和循环的应用(二分查找、字符移动、模拟登录界面)

简介: 【C语言】分支和循环的应用(二分查找、字符移动、模拟登录界面)

1.简单二分查找

在一个有序数组中查找某个具体的数n

其实要实现这个功能可以有很多种方法,但用二分查找法是一种比较优的方法。

我们可以用一般方法与二分查找的方法做一个对比:

一般方法:

int main()
{
  int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
  int k = 7;//查找数字7
  int i = 0;
  int flag = 0;
  for (i = 0; i < 10; i++)//for循环遍历数组
  {
    if (arr[i] == k)//判断每一次遍历是否与所查数字相等
    {
      printf("找到了,下标是%d\n", i);
      flag = 1;
      break;
    }
  }
  if (flag == 0)
  {
    printf("找不到\n");
  }
  return 0;
}

一般的思想就是遍历数组,然后拿要找的数字跟数组中的每一个数字进行比较,找到后返回该数字的下标。这种方法的弊端在于当数组内的个数是N个,如果要查找的数刚好是最后一个,就需要遍历整个数组,查找的速度会更慢,查找的效率更低。

二分查找:

首先要说的是二分查找的思想,数组第一个元素的下标left,最后一个元素的下标right,让两个下标相加除以2得到数组中间元素的下标mid,然后再判断该下标中数组的元素是否就是所查数字k,由于数组内的数字是顺序排列,接下来我们可以得到一次二分查找为:若mid>k,说明k的范围是[left,mid),这时将mid-1赋给right再次判断;若mid;这样每次判断后都是之前的一半,因此二分查找又被称为是折半查找,而一次查找完后没找到就要进行第二次、第三次…,把一次二分查找放进while循环中,就能实现完整的二分查找了。

如下图解:





代码如下:

#include <stdio.h>
int main()
{
  int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
  int k = 7;//要查找的数是7
  int flag = 0;
  int left = 0;
  int right = 9;
  while (left <= right)
  {
    int mid = (left + right) / 2;
    if (arr[mid] > k)
    {
      right = mid - 1;
    }
    else if (arr[mid] < k)
    {
      left = mid + 1;
    }
    else
    {
      printf("找到了!%d的下标是%d\n", k,mid);
      flag = 1;
      break;
    }
  }
  if (flag == 0)
  {
    printf("没找到!\n");
  }
  printf("\n");
  return 0;
}

这两段代码的结果是一致的

注意:要使用二分查找需要保证数组内的数字必须是有序


2.两个字符从两端移动,向中间汇聚

要想实现这个功能,首先需要两个字符数组,第一个数组存放有效字符串(如“Welcom to my home!”),第二个数组存放无意义的字符串(如“***************”),分别用left和right表示第一个字符和最后一个字符的下标,将两个字符串的第一个字符和最后一个字符进行交换,每交换一次打印一下,然后使left++,right–,再进入循环中

#include <stdio.h>
int main()
{
  char arr1[] = "Welcom to my home!";
  char arr2[] = "******************";
  int left = 0;
  int right = strlen(arr1) - 1;
  while (left < right)
  {
    arr2[left] = arr1[left];
    arr2[right] = arr1[right];
    printf("%s\n", arr2);
    left++;
    right--;
  }
  printf("\n");
  return 0;
}

strlen函数返回的是字符串中字符的个数,遇到‘\0’停止

代码结果如下:

这样看起来不是特别好看,我们可以进一步的优化

我们可以每一秒打印一次状态,这时我们需要借助两个库函数,如下:

优化后代码:

#include <stdio.h>
#include <string.h>
#include <Windows.h>
#include <stdlib.h>
int main()
{
  char arr1[] = "Welcom to my home!";
  char arr2[] = "******************";
  int left = 0;
  int right = strlen(arr1) - 1;
  while (left < right)
  {
    arr2[left] = arr1[left];
    arr2[right] = arr1[right];
    printf("%s\n", arr2);
    Sleep(1000);//Sllep()函数实现睡眠,单位是毫秒
          //间隔一秒打印一次
    system("cls");//system是一个库函数,cls是清空屏幕的命令
    left++;
    right--;
  }
  printf("\n");
  
  return 0;
}

1.Sllep()是库函数,实现睡眠,单位是毫秒,Sleep(1000)表示间隔一秒打印一次,

它需要引入头文件#include

2.system(“cls”):system也是库函数,cls是清空屏幕的命令,它需要引入头文件#include

其中一段代码结果如下:

循环应用演示

这里是每一秒打印一次当时的状态


3.模拟用户登录情景

只允许输入三次密码,三次输入错误,登录失败

我们根据如下的代码来讲解

代码如下:

#include <stdio.h>
#include <string.h>
int main()
{
  //假设密码是:字符串“123456”
  int i = 0;
  int flag = 0;
  char password[20] = { 0 };
  for (i = 0; i < 3; i++)
  {
    printf("请输入密码:>");
    scanf("%s", password);
    if (0 == strcmp(password,"123456"))
    {
      printf("登陆成功!\n");
      flag = 1;
      break;
    }
    else
    {
        printf("第%d次输入错误\n", i+1);
    }
  }
  if (0 == flag)
  {
    printf("登陆失败!\n");
  }
  return 0;
}

其实思路非常简单,正确的密码是123456,先创建一个字符数组,然后由我们输入密码,将我们输入的密码与正确密码进行比较,相同则为登录成功,不同则为登陆失败。

值得注意的是,比较两个字符串时,不能简单的进行比较,需要用到strcmp()函数

strcmp()函数比较的是两个字符的ASSIC码值

1.如果第一个字符串小于第二个字符串,返回<0的数字

2.如果第一个字符串大于第二个字符串,返回>0的数字

3.如果第一个字符串等于第二个字符串,返回0

所以我们拿strcmp(password,“123456”))与0比较,相等说明两个字符串的内容相等

两种情况下的结果如下:

登录失败

登陆成功


相关文章
|
Linux C语言 iOS开发
C语言结合AWTK开发HTTP接口访问界面
这样,我们就实现了在C语言中使用libcurl和AWTK来访问HTTP接口并在界面上显示结果。这只是一个基础的示例,你可以根据需要添加更多的功能和优化。例如,你可以添加错误处理机制、支持更多HTTP方法(如POST、PUT等)、优化用户界面等。
710 82
|
C语言
C语言中条件操作符的应用
最后,条件操作符是个超级英雄,但不是每个代码问题都需要一个超级英雄来解决。一定要在适当的时候适度的使用它,那么它将成为你的编程工具箱中的一件强力工具。
534 75
|
C语言
C语言分支和循环语句
分支语句由`if-else`构成,用于根据不同条件执行相应代码。`else`会与最近未配对的`if`结合,多个条件可用`else if`实现。若连续使用`if`,各条件互不影响。嵌套结构可在`if`中再加入`if-else`。此外,`switch`语句适用于多分支选择(注意表达式不能为浮点数,`case`后需加`break`)。循环语句包括`for`、`while`和`do...while`,注意`do...while`末尾需加分号。循环中,`break`直接终止循环,`continue`跳过当前循环剩余部分,但`for`的语句三仍会执行,而`while`中位置影响效果。
256 0
|
人工智能 Java 程序员
一文彻底搞清楚C语言的循环语句
本文介绍了C语言中的三种循环语句:`while`、`do-while`和`for`,并详细解释了它们的语法格式、执行流程及应用场景。此外,还讲解了循环控制语句`break`和`continue`的使用方法。希望这些内容能帮助你在编程道路上不断进步,共同成长!
1638 0
一文彻底搞清楚C语言的循环语句
|
C语言
【C语言程序设计——循环程序设计】枚举法换硬币(头歌实践教学平台习题)【合集】
本文档介绍了编程任务的详细内容,旨在运用枚举法求解硬币等额 - 循环控制语句(`for`、`while`)及跳转语句(`break`、`continue`)的使用。 - 循环嵌套语句的基本概念和应用,如双重`for`循环、`while`嵌套等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台将对编写的代码进行测试,并给出预期输出结果。 5. **通关代码**:提供完整的代码示例,帮助理解并完成任务。 6. **测试结果**:展示代码运行后的实际输出,验证正确性。 文档结构清晰,逐步引导读者掌握循环结构与嵌套的应用,最终实现硬币兑换的程序设计。
273 19
|
算法 C语言
【C语言程序设计——循环程序设计】求解最大公约数(头歌实践教学平台习题)【合集】
采用欧几里得算法(EuclideanAlgorithm)求解两个正整数的最大公约数。的最大公约数,然后检查最大公约数是否大于1。如果是,就返回1,表示。根据提示,在右侧编辑器Begin--End之间的区域内补充必要的代码。作为新的参数传递进去。这个递归过程会不断进行,直到。有除1以外的公约数;变为0,此时就找到了最大公约数。开始你的任务吧,祝你成功!是否为0,如果是,那么。就是最大公约数,直接返回。
485 18
|
Serverless C语言
【C语言程序设计——循环程序设计】利用循环求数值 x 的平方根(头歌实践教学平台习题)【合集】
根据提示在右侧编辑器Begin--End之间的区域内补充必要的代码,求解出数值x的平方根;运用迭代公式,编写一个循环程序,求解出数值x的平方根。注意:不能直接用平方根公式/函数求解本题!开始你的任务吧,祝你成功!​ 相关知识 求平方根的迭代公式 绝对值函数fabs() 循环语句 一、求平方根的迭代公式 1.原理 在C语言中,求一个数的平方根可以使用牛顿迭代法。对于方程(为要求平方根的数),设是的第n次近似值,牛顿迭代公式为。 其基本思想是从一个初始近似值开始,通过不断迭代这个公式,使得越来越接近。
470 18
|
C语言
【C语言程序设计——循环程序设计】统计海军鸣放礼炮声数量(头歌实践教学平台习题)【合集】
有A、B、C三艘军舰同时开始鸣放礼炮各21响。已知A舰每隔5秒1次,B舰每隔6秒放1次,C舰每隔7秒放1次。编程计算观众总共听到几次礼炮声。根据提示,在右侧编辑器Begin--End之间的区域内补充必要的代码。开始你的任务吧,祝你成功!
367 13
|
存储 C语言
【C语言程序设计——循环程序设计】利用数列的累加和求 sinx(头歌实践教学平台习题)【合集】
项的累加和,一般会使用循环结构,在每次循环中计算出当前项的值(可能基于通项公式或者递推关系),然后累加到一个用于存储累加和的变量中。在C语言中推导数列中的某一项,通常需要依据数列给定的通项公式或者前后项之间的递推关系来实现。例如,对于一个简单的等差数列,其通项公式为。的级数,其每一项之间存在特定的递推关系(后项的分子是其前项的分子乘上。,计算sinx的值,直到最后一项的绝对值小于。为项数),就可以通过代码来计算出指定项的值。对于更复杂的数列,像题目中涉及的用于近似计算。开始你的任务吧,祝你成功!
419 6
|
C语言
【C语言程序设计——循环程序设计】鸡兔同笼问题(头歌实践教学平台习题)【合集】
本教程介绍了循环控制和跳转语句的使用,包括 `for`、`while` 和 `do-while` 循环,以及 `break` 和 `continue` 语句。通过示例代码详细讲解了这些语句的应用场景,并展示了如何使用循环嵌套解决复杂问题,如计算最大公因数和模拟游戏关卡选择。最后,通过鸡兔同笼问题演示了穷举法编程的实际应用。文中还提供了编程要求、测试说明及通关代码,帮助读者掌握相关知识并完成任务。 任务描述:根据给定条件,编写程序计算鸡和兔的数量。鸡有1个头2只脚,兔子有1个头4只脚。
847 5