母牛的故事 替换空格 二进制中1的个数 不使用第三个变量交换a,b的值

简介: 母牛的故事 替换空格 二进制中1的个数 不使用第三个变量交换a,b的值

1.母牛的故事


题目链接:传送门


有一头母牛,它每年年初生一头小母牛。每头小母牛从第四个年头开始,每年年初也生一头小母牛。请编程实现在第n年的时候,共有多少头母牛?


输入描述:
输入数据由多个测试实例组成,每个测试实例占一行,
包括一个整数n(0<n<55),n的含义如题目中描述。


输出描述:
对于每个测试实例,输出在第n年的时候母牛的数量。
每个输出占一行。


解题思路:


因为前四年都是由一头成年牛生产小牛牛,所以前四年的数量分别是

{1,2,3,4,},从第5年开始则不同,因为第2年生产的小牛牛已经长大了,也可以生产了。


我们以第五年为例:


第5年牛牛数量=原来牛的数量+新增牛的数量


原来牛的数量:指上一年的数量,即第四年牛牛的数量。


新增牛的数量:第五年有哪些牛出生就是新增牛的数量,显然此时第2年牛的数量就为新增牛的数量,因为到第五年的时候第2年所有的牛都是成年牛了,所以都可以生小牛。


第n年牛牛的数量为=原来牛的数量(n-1年)+新增牛的数量(n-3年)


重点:很多小伙伴还是不理解为什么是n-3年,


因为


第一年: n-3题目看仔细哦,小牛是年初出生的,所以到n-3年结束,这里也是一年哦。


第二年 :n-2


第三年 :n-1


第四年 : n(年初生产了)


代码实现:

#include <stdio.h>
#define N 55
int main()
{
  //定义一个一维数组,用于存放每一年牛的数量
  int a[N] = {0,1,2,3,4};
  int i = 0, n = 0;
  while (scanf("%d", &n) != EOF)//用于多组输入
  {
    for (i = 5; i <= n; i++)//从第五年开始,有小牛出生
    {
      //去年牛的数量+新出生的小牛的数量
      a[i] = a[i - 1] + a[i- 3];
    }
    printf("%d\n", a[n]);//输出这一年牛的数量
  }
  return 0;
}


最后:如有不了解多组输入的小伙伴。


请参照:scanf(“%d”, &n) != EOF,


2.替换空格


题目链接:传送门


描述:


请实现一个函数,将一个字符串s中的每个空格替换成“%20”。


例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。


数据范围:1000 \0≤len(s)≤1000 。保证字符串中的字符为大写英文字母、小写英文字母和空格中的一种。


示例1
输入:
"We Are Happy"
复制
返回值:
"We%20Are%20Happy"
复制
示例2
输入:
" "
复制
返回值:
"%20"


解题思路:


  1. 首先,我们观察到返回值是一串字符,所以我们可以创建一个足够大的数组来存储返回字符串.


  1. 其次题目要求是将目标字符串中的“空格”替换为“%20”,这里特别注意的是“%20“是三个字符(‘%’,‘2’,‘0’组成).所以我们不能直接将"空格"赋值为”%20”.


  1. 我们遍历目标字符数组(字符串)时,遇到空格,就将空格和空格后的两个字符都占据,这样就可以有三个字符空间来分别存储’%’ ‘2’ ‘0’.了


  1. 最后将返回值字符串返回即可.


代码实现


/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 *
 * @param s string字符串
 * @return string字符串
 */
char* replaceSpace(char* s ) {
    // write code here
    char ret[10000]={0};//创建一个用于存放返回字符串的数组
    int i=0;
   for(i=0;*s!='\0';i++)
    {
        if(*s==' ')//如果遇到空格,就用三个字符来存储%20
        {
           ret[i]='%';
           ret[i+1]='2';
           ret[i+2]='0';
           i=i+2;
        }
        else{
            ret[i]=*s;//不是空格则直接存储
        }
        s++;
    }
    return ret;
}


3.二进制中1的个数(操作符之小试牛刀)


题目链接:传送门


题目描述:


输入一个整数 n ,输出该数32位二进制表示中1的个数。其中负数用补码表示。


数据范围:- 2^{31} <= n <= 2^{31}-1−2


即范围为:-2147483648<= n <= 2147483647−2147483648<=n<=2147483647


示例1
输入:
10
复制
返回值:
2
复制
说明:
十进制中10的32位二进制表示为0000 0000 0000 0000 0000 0000 0000 1010
,其中有两个1。       
示例2
输入:
-1
复制
返回值:
32
复制
说明:
负数使用补码表示 ,-1的32位二进制表示为
1111 1111 1111 1111 1111 1111 1111 1111,其中32个1    


解题思路


方法1:


当一个数n&1的时候,我们就可以得到n这个数的最低位.是否为1,为1则会返回1,反之返回0.

例如:



我们可以用">>"(逻辑右移操作符)每次移动一位后&1,判断最后一位是否为1.


方法2:


这个方法很巧妙,其实当我们用n&n-1的时候,每次都会减少二进制中的一个1.直到n为0;


例如:53


第一次相&



第二次相&



第三次相&



第四次相&



代码实现


//方法1
int NumberOf1(int n ) {
int count=0,i=0;
    for (i = 0; i < 32; i++)
  {
    if (1 == ((n >> i) & 1))//每次移动i个位置
    {
      count++;
    }
  }
  return count;
}


//方法2
int NumberOf1(int n ) {
    int count = 0;
  while (n)
  {
    n&=(n - 1);
    count++;
  }
  return count;
}


新增题:


4.经典面试题(操作符之小试牛刀)


题目描述:


已定义int a=3,b=5;在不使用第三个变得的情况下交换a与b的值.


输出:a=5,b=3;


方法一:


#include <stdio.h>
int main()
{
  int a = 3, b = 5;
  a = a + b;
  b = a - b;//此时a=a+b
  a = a - b;//此时b=a;
  printf("a=%d,b=%d", a, b);
  return 0;
}


方法2:


#include <stdio.h>
int main()
{
  int a = 3, b = 5;
  a = a ^ b;
  b = a ^ b;//此时a=a^b
  a = a ^ b;//此时b=a
  printf("a=%d,b=%d", a, b);
  return 0;
}


方法一的思路看代码相信大家都可以看懂,方法2,就有点迷糊了,其实通过看二进制的位的变化才可以看懂,但是这谁能想的到啊,牛牛也想不到,但是想不到的东西多了去了,我学会就是我的.😄😄😄


提示:


n^n=0;

目录
相关文章
|
Kubernetes 关系型数据库 MySQL
ChaosBlade常见问题之数据库进行故障注入报错ibdata1文件异常如何解决
ChaosBlade 是一个开源的混沌工程实验工具,旨在通过模拟各种常见的硬件、软件、网络、应用等故障,帮助开发者在测试环境中验证系统的容错和自动恢复能力。以下是关于ChaosBlade的一些常见问题合集:
494 1
|
前端开发 JavaScript Java
现代化软件开发中的前后端分离模式
随着互联网技术的快速发展,现代化软件开发中的前后端分离模式逐渐成为主流。本文将介绍前后端分离的概念和优势,以及如何在不同的技术栈中实现这种模式。通过前后端分离,可以提高开发效率、降低耦合性,并且更好地满足用户需求。
982 0
|
9月前
|
SQL 自然语言处理 数据可视化
📊 Quick BI 真实体验评测:小白也能快速上手的数据分析工具!
作为一名软件开发工程师,我体验了阿里云的Quick BI工具。从申请试用账号到上传数据、创建数据集,再到搭建仪表板和使用智能小Q功能,整个过程流畅且简单易用。尤其对非专业数据分析人士来说,拖拽式设计和自然语言问数功能极大降低了操作门槛。虽然在试用入口明显度和复杂语义理解上还有提升空间,但整体体验令人满意。Quick BI让我改变了对数据分析的认知,值得推荐给需要快速制作报表的团队成员。
|
安全 数据挖掘
服务器数据恢复—RAID5阵列中两块硬盘离线导致阵列崩溃的数据恢复案例
服务器数据恢复环境: 两组分别由4块SAS接口硬盘组建的raid5阵列,两组raid5阵列划分LUN并由LVM管理,格式化为EXT3文件系统。 服务器故障: RAID5阵列中一块硬盘未知原因离线,热备盘自动激活上线替换离线硬盘。在热备盘上线过程中,raid5阵列中又有一块硬盘离线。热备盘同步失败,该raid阵列崩溃,LVM结构变得不完整,文件系统无法正常使用。
|
关系型数据库 分布式数据库 数据库
PolarDB,阿里云的开源分布式数据库,与微服务相结合,提供灵活扩展和高效管理解决方案。
【7月更文挑战第3天】PolarDB,阿里云的开源分布式数据库,与微服务相结合,提供灵活扩展和高效管理解决方案。通过数据分片和水平扩展支持微服务弹性,保证高可用性,且兼容MySQL协议,简化集成。示例展示了如何使用Spring Boot配置PolarDB,实现服务动态扩展。PolarDB缓解了微服务数据库挑战,加速了开发部署,为云原生应用奠定基础。
627 3
|
关系型数据库 MySQL Java
|
消息中间件 容灾 Kafka
AutoMQ 产品动态 | 企业版正式上线阿里云、AWS 中国区云市场
AutoMQ在2024年3-4月推出企业版服务,现已上线阿里云和AWS中国区云市场,用户可自助开通。支持按小时和包年包月付费,以及订阅许可证模式,实现跨IDC环境交付。企业版提供同城3AZ容灾集群,确保服务高可用。此外,还推出了Kafka全托管迁移工具和集群自助版本升级功能,保障平滑迁移和无缝升级。详情见参考资料。AutoMQ团队由Apache RocketMQ和Linux LVS核心成员组成,致力于提供成本优化和高效弹性的消息队列服务。
378 0
AutoMQ 产品动态 |  企业版正式上线阿里云、AWS 中国区云市场
|
数据安全/隐私保护
滞回曲线处理器,骨架曲线,延性系数,耗能面积
为了批量处理拟静力试验得到的滞回曲线,计算骨架曲线,延性系数,耗能等指标,开发了“滞回曲线处理器”软件,具体功能介绍如下,软件在文末获取。
滞回曲线处理器,骨架曲线,延性系数,耗能面积
|
弹性计算 Java 关系型数据库
阿里云的e实例评测
阿里云的e实例是一款针对个人开发者、学生、小微企业的入门级云服务器,旨在满足中小型网站建设、开发测试、轻量级应用等场景的需求。
521 5
|
存储 Linux KVM

热门文章

最新文章