当前位置: 首页 > news >正文

保定网站优化排名贵州网站建设gzzctyi

保定网站优化排名,贵州网站建设gzzctyi,国内自适应网站案例,seo指什么复杂度的OJ例题 一、消失的数字1.思路一2.思路二3.思路三 二、旋转数组1.思路一2.思路二3.思路三 一、消失的数字 数组nums包含从0到n的所有整数,但其中缺了一个。请编写代码找出那个缺失的整数。你有办法在O(N)时间内完成吗? 链接:力扣&…

复杂度的OJ例题

  • 一、消失的数字
    • 1.思路一
    • 2.思路二
    • 3.思路三
  • 二、旋转数组
    • 1.思路一
    • 2.思路二
    • 3.思路三

一、消失的数字

数组nums包含从0到n的所有整数,但其中缺了一个。请编写代码找出那个缺失的整数。你有办法在O(N)时间内完成吗?
链接:力扣:消失的数字

1.思路一

排序+遍历:如果下一个数据不等于上一个数据加1,那么下一个数据就是那个消失的数字。
时间复杂度:O(N*LogN)由于这个时间复杂度时间复杂度过高,本思路不再冗余,赘述。

2.思路二

利用等差数列公式:从0加到n,然后再减去这个数组中的所有数字,那么最终所得的差就是缺失的数字。
时间复杂度:O(N)
代码如下:

#include <stdio.h>
int missingNumber(int* nums, int numsSize)
{int N = numsSize;int ret = N * (N + 1) / 2;for (int i = 0; i < N; i++){ret -= nums[i];}return ret;
}int main()
{int nums[] = { 0,1,2,3,4,5,7,8,9,10 };int sz = sizeof(nums) / sizeof(nums[0]);int ret=missingNumber(nums,sz);printf("%d", ret);return 0;
}

3.思路三

单身狗思路:利用:按位异或运算符:^(相同为0,相异为1)任何数字和0 ^ 还等于它本身。首先我们要把一个完整的数组按位异或起来,然后再与题目中缺失一个数字的数组再进行按位异或,最终得到的结果就是消失的数字。
代码如下:

#include <stdio.h>
int missingNumber(int* nums, int numsSize)
{int N = numsSize;int x = 0;//第1个循环的目的:先把一个完整的数组:从0~n的所有数字全部按位异或起来存放在一个数字x中//注意:这里循环的终止条件是:<=N,(因为我们连N也要算上)for (int i = 0; i <= N; i++){x ^= i;}//第2个循环的目的:就是让一个完整的数组与缺失一个数字的数组进行按位异或,最终得到的结果就是那个消失的数字!//注意:这里循环的终止条件是:<N,(因为nums数组中确失一个数字)for (int i = 0; i < N; i++){x ^= nums[i];}return x;
}int main()
{int nums[] = { 0,1,2,3,4,5,7,8,9,10 };int sz = sizeof(nums) / sizeof(nums[0]);int ret=missingNumber(nums,sz);printf("%d", ret);return 0;
}

二、旋转数组

链接力扣:旋转数组

1.思路一

中规中矩:依次向左旋转K个数据
合计旋转:K%N次
时间复杂度:O(N^2)
空间复杂度:O(1)
因为时间复杂度超过限制,所以说不予实现。

2.思路二

核心思想:以空间换时间:我额外开辟一个数组,直接复制从k开始后面所有数据到前面,然后把复制n-k的数字放后面。
时间复杂度:O(N)
空间复杂度:O(N)
在这里插入图片描述
代码如下:

void rotate(int* nums, int numsSize, int k)
{int n = numsSize;int* tmp = (int*)malloc(sizeof(int) * n);k %= n;//一定别忘了k%n!memcpy(tmp, &nums[n - k], sizeof(int) * k);memcpy(&tmp[k], nums, sizeof(int) * (n - k));memcpy(nums, tmp, sizeof(int) * n);free(tmp);//一定别忘了Free!!!因为是动态开辟的空间
}int main()
{int nums[] = { 1,2,3,4,5,6,7 };int k = 0;printf("请输入你想要旋转的次数:");scanf("%d", &k);int sz = sizeof(nums) / sizeof(nums[0]);rotate(nums, sz, k);for (int i = 0; i < sz; i++){printf("%d ", nums[i]);}return 0;
}

3.思路三

数学思想:以k为划分界线,左边逆置,右边逆置,整体逆置。

在这里插入图片描述
代码如下:

//逆置函数
void Inversion(int* nums, int left, int right)
{while (left < right){int tmp = nums[left];nums[left] = nums[right];nums[right] = tmp;left++;right--;}
}
//旋转函数
void rotate(int* nums, int numsSize, int k)
{int n = numsSize;k %= n;Inversion(nums, 0, n - k - 1);//左边逆置Inversion(nums, n - k, n - 1);//右边逆置Inversion(nums, 0, n - 1);//整体逆置}int main()
{int nums[] = { 1,2,3,4,5,6,7 };int k = 0;printf("请输入你想要旋转的次数:");scanf("%d", &k);int sz = sizeof(nums) / sizeof(nums[0]);rotate(nums, sz, k);for (int i = 0; i < sz; i++){printf("%d ", nums[i]);}return 0;
}

好了,今天的分享就到这里了
如果对你有帮助,记得点赞👍+关注哦!
我的主页还有其他文章,欢迎学习指点。关注我,让我们一起学习,一起成长吧!
在这里插入图片描述

http://www.yayakq.cn/news/509017/

相关文章:

  • rar在线解压缩网站360建筑网怎么删除简历
  • 单位网站建设的不足温州专业手机网站制作哪家好
  • 做地方的门户网站百度推广一年多少钱
  • 南京网站设计制作排名网站开发合同免费模板
  • 陕西省建设资格注册中心网站东莞营销网站建设报价
  • 不需要丢链接可以百度收录的网站茂名东莞网站建设
  • 个人网站备案材料填写汉中中药材初加工平台
  • 沈阳网站seo排名优化人工智能需要学哪些课程
  • 买网站自己做wordpress dux
  • 唐山玉田孤树做宣传上什么网站网页设计公司的产品网站
  • 2015网站建设源码给别人做网站别人违法经营
  • 深圳网站建设高端温州seo公司排名
  • 在线做试卷的网站电子商务系统的建设过程
  • 中小型网站建设资讯网站备案不注销有什么后果
  • 网站后台上传木马教程联合早报 即时消息
  • 可以做两个网站指向同一个域名网页制作培训心得体会
  • python做网站步骤北京seo培训机构
  • 西安企业网站制作深圳罗湖企业网站建设
  • 男女做爰网站seo排名优化公司价格
  • 网站建设app开发公司网站域名后缀代表什么
  • 为什么电子网站开发cms app
  • 网站首页代码模板如何更换网站模板
  • 获取网站访问者qq号做我女朋友程序网站
  • 网站如何做数据储存的建站之星网站建设系统
  • 中山企业网站建设方案阿里巴巴对外贸易平台
  • 怎么看网站服务器地址商丘搜索引擎优化
  • 无锡专业网站推广手机网站好处
  • 天津市建设信息网官网seo 0xu
  • 网站内页修改关键字wordpress 微博登陆不了
  • 道滘镇仿做网站问答社区网站建设