算法每日一题——第五天——笨拙的手指

简介: 算法每日一题——第五天——笨拙的手指


原题链接:2058. 笨拙的手指 - AcWing题库

分析

(1)这道题的输入有两个,一个二进制数,一个三进制数,这两个数都有且只有一位数被写错,题目要求完成一段代码,求出正确的数。

(2)二进制数只有两种数字,要么是 1 ,要么是 0 ;三进制数有三种数字,0 ,1 ,2。

(3)这道题数据范围,正确的N是不超过的十进制数,看下图:

(4) 最大的N对应的是32位二进制数,那么我们就可以考虑使用暴力枚举的方法来解决这道题。

(5)因为二进制每一位数字的可能性少,我们果断选择枚举二进制数的每一位。

解析

以题目所给样例为例:

(1)1010只有一位数字被写错,那么正确的数可能是 0010     1110      1000      1011

(2)将这四种可能性化为三进制的形式   100    22    112    2

(3)这四个数中只有一个数是正确的,我们拿这四个数与212比较:

       100与212,三个数字都不同,100不是正确的数。

       22与212,两个数字不同,22不是正确的数。

      112与212,只有一个数字不同,说明112是正确的数。

代码实现

在完成这道题时,需要实现两个功能:二进制数化为三进制数      判断两个三进制数有几位数字不同

想要将二进制数直接化为三进制数比较困难(可能是因为我比较菜),我们可先将二进制数化为十进制数,再将十进制数化为三进制数

(1)二进制数化为十进制数

int Conversion1(char* i)
{
  int rnt = 0;
  int m = 0;
  int x = strlen(i);
  for (m = 0; m < x; m++)
  {
    if (i[m] == '1')
    {
      rnt += pow(2, x - m - 1);
    }
  }
  return rnt;
}

(2)十进制数化为三进制数

char* Conversion2(int m)
{
  int i = 0;
  char* rnt = (char*)malloc(sizeof(char) * 10);
  while (m)
  {
    rnt[i] = (m % 3)+'0';
    m = m / 3;
    i++;
  }
  rnt[i] = '\0';
  int tmp = 0;
  int n = i - 1;
  for (int m = 0; m < i / 2; m++)
  {
    tmp = rnt[n];
    rnt[n] = rnt[m];
    rnt[m] = tmp;
    n--;
  }
  return rnt;
}

(3)判断两个三进制数有几位数字不同

int Count(char* x, char* y)
{
  int rnt = 0;
  int end1 = strlen(x)-1;
  int end2 = strlen(y)-1;
  while (end1 >= 0 && end2 >= 0)
  {
    if (x[end1] != y[end2])
    {
      rnt++;
    }
    end1--;
    end2--;
  }
  if (end1 >= 0)
  {
    rnt += end1 + 1;
  }
  if (end2 >= 0)
  {
    rnt += end2 + 1;
  }
  return rnt;
}

(4)完整代码

#include<stdio.h>
#include<string.h>
#include<math.h>
#include<stdlib.h>
int Conversion1(char* i)
{
  int rnt = 0;
  int m = 0;
  int x = strlen(i);
  for (m = 0; m < x; m++)
  {
    if (i[m] == '1')
    {
      rnt += pow(2, x - m - 1);
    }
  }
  return rnt;
}
char* Conversion2(int m)
{
  int i = 0;
  char* rnt = (char*)malloc(sizeof(char) * 10);
  while (m)
  {
    rnt[i] = (m % 3)+'0';
    m = m / 3;
    i++;
  }
  rnt[i] = '\0';
  int tmp = 0;
  int n = i - 1;
  for (int m = 0; m < i / 2; m++)
  {
    tmp = rnt[n];
    rnt[n] = rnt[m];
    rnt[m] = tmp;
    n--;
  }
  return rnt;
}
int Count(char* x, char* y)
{
  int rnt = 0;
  int end1 = strlen(x)-1;
  int end2 = strlen(y)-1;
  while (end1 >= 0 && end2 >= 0)
  {
    if (x[end1] != y[end2])
    {
      rnt++;
    }
    end1--;
    end2--;
  }
  if (end1 >= 0)
  {
    rnt += end1 + 1;
  }
  if (end2 >= 0)
  {
    rnt += end2 + 1;
  }
  return rnt;
}
int main()
{
  int i=0;
  char a[40];
  char b[40];
  char *c;
  scanf("%s", a);
  scanf("%s", b);
  while (1)
  {
    if (a[i] == '0')
    {
      a[i] = '1';
    }
    else
    {
      a[i] = '0';
    }
    c=Conversion2(Conversion1(a));
    if (Count(c, b) == 1)
    {
      printf("%d", Conversion1(a));
      return 0;
    }
    else
    {
      if (a[i] == '0')
      {
        a[i] = '1';
      }
      else
      {
        a[i] = '0';
      }
    }
    i++;
  }
} 
相关文章
|
9月前
|
存储 算法 安全
C# | 上位机开发新手指南(五)校验算法——CRC
当我们在进行数据传输时,可能会因为信道噪声、干扰等因素导致数据出现错误,从而影响传输的可靠性和准确性。此时,我们需要一种方法来检测数据是否出现错误,并尽可能快速地发现和纠正错误。CRC(Cyclic Redundancy Check)校验算法就是一种常用的数据校验方法,它通过对数据进行处理生成校验码,从而实现对数据的完整性和准确性进行验证。 使用CRC校验的意义在于能够提高数据传输的可靠性,降低数据传输错误率,确保数据的完整性和准确性。在各个领域中,如通信、网络、存储等,CRC校验都得到了广泛的应用。
382 0
C# | 上位机开发新手指南(五)校验算法——CRC
|
9月前
|
算法 C#
C# | 上位机开发新手指南(四)校验算法
校验算法是一种用于验证数据传输过程中是否出现错误或丢失的算法。 在数据传输过程中,由于噪声、干扰、传输错误等因素的影响,会导致数据传输过程中出现错误或丢失。 为了保证数据传输的准确性,需要在数据传输过程中添加校验码。发送端通过计算数据的校验码并将其附加到数据中一起发送出去,接收端再次计算校验码并将其与接收到的校验码进行比较,如果两者相同,则说明数据传输过程中没有出现错误或丢失。
292 0
C# | 上位机开发新手指南(四)校验算法
|
算法 Java C++
算法题:笨拙的手指
题目来源:AcWing2058 奶牛贝茜正在学习如何在不同进制之间转换数字。 但是她总是犯错误,因为她无法轻易的用两个前蹄握住笔。
96 0
笨拙的手指——acwing算法题第一天
笨拙的手指——acwing算法题第一天
笨拙的手指——acwing算法题第一天
|
机器学习/深度学习 传感器 人工智能
意念加AI算法「复原」每个手指,智能义肢登上Nature子刊封面
使用「意念」控制机械,让肢体缺失的残疾人过上正常人的生活,这听起来像是出现在电影中的场景。最近,瑞士洛桑联邦理工学院(EPFL)展示的新技术却让科幻变成了现实,他们的研究还登上了最新一期自然杂志子刊《Nature Machine Intelligence》的封面。
262 0
意念加AI算法「复原」每个手指,智能义肢登上Nature子刊封面
|
算法 开发工具 芯片
如何创建一个Flash算法文件 | 《平头哥剑池CDK快速上手指南》第三章
CDK支持Flash烧写功能,为了能够适配不同的Flash器件的编程逻辑,CDK允许开发人员通过Flash算法文件的适配,实现Flash器件的编程,从而实现对某个芯片平台的Flash烧写。
如何创建一个Flash算法文件 | 《平头哥剑池CDK快速上手指南》第三章
|
23天前
|
算法 数据安全/隐私保护 计算机视觉
基于Retinex算法的图像去雾matlab仿真
本项目展示了基于Retinex算法的图像去雾技术。完整程序运行效果无水印,使用Matlab2022a开发。核心代码包含详细中文注释和操作步骤视频。Retinex理论由Edwin Land提出,旨在分离图像的光照和反射分量,增强图像对比度、颜色和细节,尤其在雾天条件下表现优异,有效解决图像去雾问题。
|
23天前
|
算法 数据可视化 安全
基于DWA优化算法的机器人路径规划matlab仿真
本项目基于DWA优化算法实现机器人路径规划的MATLAB仿真,适用于动态环境下的自主导航。使用MATLAB2022A版本运行,展示路径规划和预测结果。核心代码通过散点图和轨迹图可视化路径点及预测路径。DWA算法通过定义速度空间、采样候选动作并评估其优劣(目标方向性、障碍物距离、速度一致性),实时调整机器人运动参数,确保安全避障并接近目标。
121 68
|
1月前
|
算法 数据安全/隐私保护
室内障碍物射线追踪算法matlab模拟仿真
### 简介 本项目展示了室内障碍物射线追踪算法在无线通信中的应用。通过Matlab 2022a实现,包含完整程序运行效果(无水印),支持增加发射点和室内墙壁设置。核心代码配有详细中文注释及操作视频。该算法基于几何光学原理,模拟信号在复杂室内环境中的传播路径与强度,涵盖场景建模、射线发射、传播及接收点场强计算等步骤,为无线网络规划提供重要依据。
|
1月前
|
机器学习/深度学习 数据采集 算法
基于GA遗传优化的CNN-GRU-SAM网络时间序列回归预测算法matlab仿真
本项目基于MATLAB2022a实现时间序列预测,采用CNN-GRU-SAM网络结构。卷积层提取局部特征,GRU层处理长期依赖,自注意力机制捕捉全局特征。完整代码含中文注释和操作视频,运行效果无水印展示。算法通过数据归一化、种群初始化、适应度计算、个体更新等步骤优化网络参数,最终输出预测结果。适用于金融市场、气象预报等领域。
基于GA遗传优化的CNN-GRU-SAM网络时间序列回归预测算法matlab仿真