数组面试

1.数组求和

如果只是普通求和会简单,但是只能使用一行代码该怎么办呢?

int sum(int *a,int n)
{return n ==0 ? 0 : sum(a,n-1) + a[n-1]; 
}

2.寻找发帖水王

int Find(int *a,int n)
{int times = 0;int value;for (int i = 0;i < n;++i){if (times == 0){value = a[i];times = 1;}else{if (a[i] == value){times++;}elsetimes--;}}return value;
}int main()
{int a[10] = {1,1,1,7,8,1,1,1,2,4};cout <<Find(a,10) <<endl;return 0;
}

 3.求最大值和最小值

void arrmax(int *a,int n)
{max = 0;min = 0;for (int i = 0;i < n;++i){if (a[i] >max){max = a[i];}if (a[i] < min){min = a[i];}}
}

 4.最大值和次大值

void arrmax(int *a,int n)
{max = 0;min = 0;for (int i = 0;i < n;++i){if (a[i] >max){max = a[i];}if (a[i] < min){min = a[i];}}
}

 5.求数组中最短两个元素之间的距离

因为最短距离只可能是相邻元素之间的距离,所以转化为排序问题,时间复杂度O(N*logN);

6.找出两个数组的共同元素

void arrmax(int *a,int *b,int n)
{int i = 0;int j = 0;while(i <n && j <n){if (a[i] < b[j]){i++;}else if (a[i] == b[j]){cout << a[i] <<endl;i++;j++;}else{j++;}}
}int main()
{int a[5] = {0,1,2,3,4};int b[5] = {1,3,5,7,9};arrmax(a,b,5);return 0;
}

7.找出数组中唯一重复的元素

给定含有1001个元素的数组,其中存放了1-1000之内的整数,只有一个整数是重复的,请找出这个数

先对这个数组进行求和,然后减去1到1000的和。

8.找出出现奇数次的数

给定一个含有n个元素的整型数组a,其中只有一个元素出现奇数次,找出这个元素 

因为对于任意一个数k,有k ^ k = 0,k ^ 0 = k,所以将a中所有元素进行异或,那么个数为偶数的元素异或后都变成了0,只留下了个数为奇数的那个元素。

int findOdd(int *a,int n)
{int r = a[0];for (int i = 1;i < n;++i){r^= a[i];}return r;
}int main()
{int a[11] = {1,1,4,3,4,6,8,8,9,3,6};cout << findOdd(a,11)<<endl;return 0;
}

 9.找出数组中给定值的数对

有两种情况,一种是经过排序的,一种是没有经过排序的

没有经过排序的需要用一个额外的数组做标记。然后对判断下标进行操作。这里的下标就是数组里的数。

void findSum(int *a,int n,int sum)
{int ahead = n -1;int behind = 0;int curSum = 0;while(behind < ahead){curSum = a[ahead] + a[behind];if (curSum == sum){cout << a[ahead] << "," <<a[behind] <<endl;break;}else if (curSum > sum){ahead--;}else{behind++;}}
}
int main()
{int a[10] = {1,2,4,6,8,9,12,13,15,19};findSum(a,10,18);return 0;
}

 10.找出数组最大字段和

int findSum(int *a,int n)
{int cur = 0;int sum = 0;for (int i = 0;i < n;++i){cur = a[i] +cur;if (cur < 0){cur = 0;}if (cur > sum){sum = cur;}}return sum;
}
int main()
{int a[8] = {1,-2,3,10,-4,7,2,-5};cout <<  findSum(a,8);return 0;
}
11.数组最大字段乘积
// 子数组的最大乘积
int MaxProduct(int *a, int n)
{int maxProduct = 1; // max positive product at current positionint minProduct = 1; // min negative product at current positionint r = 1; // result, max multiplication totallyfor (int i = 0; i < n; i++){if (a[i] > 0){maxProduct *= a[i];minProduct = min(minProduct * a[i], 1);}else if (a[i] == 0){maxProduct = 1;minProduct = 1;}else // a[i] < 0{int temp = maxProduct;maxProduct = max(minProduct * a[i], 1);minProduct = temp * a[i];}r = max(r, maxProduct);}return r;
}

 

转载于:https://www.cnblogs.com/liuweilinlin/p/3282346.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/460825.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

分析根文件系统中的etc/init.d/rcS文件

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 一、文件简介 &#xff08;1&#xff09;由博文分析根文件系统中的/etc/inittab文件可知&#xff0c;etc/inittab文件的第一行配置项一般是“::sysinit:/etc/init.d/rcS”&#xff0c;这说明控制台…

拼多多显示内部服务器错误是怎么回事,拼多多提现出现错误怎么办?拼多多提现常见问题...

拼多多提现是每个店家都会去操作的&#xff0c;不过提现时总会遇到很多问题&#xff0c;例如手机号码换了收不到验证码、提现资金到账时间、提现出现错误等等&#xff0c;当然还有很多。当这些问题出现时我们应该如何去解决呢?1、如果出现银行提现手机号非现使用手机号&#x…

分析根文件系统中的用户登录(主要涉及/etc/profile、/etc/intttab、/etc/passwd和/etc/shadow等文件)

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 一、简单分析/etc/profile文件 1、何时被调用 这个文件直接或者间接地被/linuxrc文件调用。 2、文件简介 &#xff08;1&#xff09;busybox源码中的/examples/bootfloopy/etc/profile文件内容过于简…

VirtualBox 扩展虚拟硬盘容量

为什么80%的码农都做不了架构师&#xff1f;>>> 扩展步骤&#xff1a;第一步&#xff1a;修改硬盘镜像文件 1、虚拟机关机. 2、确认虚拟机使用文件(后缀为.vdi的文件)路径不带中文字符&#xff0e; 3、Windows 下按&#xff1a;Windows R&#xff0c;调出命令行工具…

jquery控制css的display(控制元素的显示与隐藏)

使用jquery控制div的显示与隐藏: $("#div的id").show()表示display:block, $("#div的id").hide()表示display:none; $("#id").toggle()切换元素的可见状态&#xff1a;如果元素是可见的&#xff0c;切换为隐藏的&#xff1b;如果元素是隐藏的&am…

制作ext2格式的根文件系统镜像

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 1、首先验证文件夹形式的rootfs是否可用 设置bootargs为nfs启动方式&#xff0c;然后使用在ubuntu中做好的文件夹形式的rootfs来启动&#xff0c;查看启动效果&#xff0c;作为将来用ext2格式的root…

技术和赚钱真的冲突吗?

前几天在微信上看到篇文章&#xff0c;讲述的是大悲寺和少林寺的对比。原文的大意是大悲寺如何如何清苦&#xff0c;烧香不许客户投钱。而少林寺如何的肥头大耳&#xff0c;尤其是方丈释永信是多么多么的会“敛财“。&#xff08;注意&#xff1a;我们这里抛去一些“确实是敛财…

构造和运行模块

作者&#xff1a;蔡伦辉写在前面作者一直支持GPL的精神。允许任何人自由使用、转载、复制和再分发&#xff0c;但必须保留作者署名&#xff0c;必须保证全文完整转载&#xff0c;包括完整的版权声明。由于作者水平有限&#xff0c;因此不能保证文章内容准确无误&#xff0c;请批…

分析与构建根文件系统中的/lib目录

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 由根文件系统的目录结构_天糊土的博客-CSDN博客可知&#xff0c;/lib目录在根文件系统中也是不能省略的。该目录存放着操作系统中的动态和静态链接库文件。我们构建/lib目录&#xff0c;主要工作是是…

优化小技巧——复杂属性对象的read模式

本帖最后由 Aone 于 2013-7-27 12:23 编辑想必Rectangle或者Point这样的数据类在我们的程序中特别是当前的游戏中是非常常用的类型。那么一些类中获取这些属性的时候为了封装&#xff0c;往往会写一个get函数return一个复制的Rectangle对象给外部。目的是为了防止被获取内部rec…

从零开始构建根文件系统

以下内容源于网络资源的学习与整理&#xff0c;如有侵权请告知删除。 参考博客 Uboot和系统移植&#xff08;19&#xff09;------- 根文件系统构建过程详解_big__C的博客-CSDN博客 一、总结 &#xff08;1&#xff09;本节在前面的理论分析的基础上&#xff0c;我们开始从零开…

Perl常用语法记录

Perl常用语法记录##包的切换和调用其它包的方式 #package A; #my $a10;#package B; #print $A::a; #print $a;##local局部标识符的使用 #$aa20; #{ # local $aa; # $aa10; # print "$aa \n"; # #}#print $aa;##别名的使用 comment $b10; $a1; $c200; {local *b;*b*a…

关于uboot的简介——uboot常用的命令

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 linux终端设计有3种缓冲机制&#xff1a;无缓冲、行缓冲、全缓冲。 uboot提供类似linux终端的行缓冲命令行。当我们向终端命令行输入命令的时候&#xff0c;这些命令没有立即被系统识别&#xff0c…

网站分析

网网站分析(Web Analytics) 是种网站访客行为的研究。于商务应用背景来说&#xff0c;网站分析特别指的是来自某网站搜集来的资料之使用&#xff0c;以决定网站布局是否符合商业目标&#xff1b;例如&#xff0c;哪个登陆页面(landing page)比较容易刺激顾客购买欲。这些搜集来…

关于uboot的简介——uboot常见的环境变量

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 如何理解环境变量呢&#xff1f;环境变量就好像程序的全局变量一样。程序中任何地方都可以根据需要去调用或者更改环境变量&#xff08;一般都是调用&#xff09;&#xff0c;环境变量和全局变量不同…

奋战杭电ACM(DAY9)1013

Digital Roots #include <iostream> #include <string> using namespace std;int main() {string s;//溢出神烦哈&#xff01;int m,n,i;while(cin >> s){ m0;if(s[0]0) break;for(i0; s[i]!\0; i)ms[i]-0;//转换为int&#xff0c;巧妙&#xff01;n ((m%…

工作两个月的感受随笔

转眼之间&#xff0c;已经离毕业三个月了&#xff0c;在格力凌达工作了近两个月&#xff0c;在这边的主要感受有&#xff1a;两不会&#xff1a;这也不会&#xff0c;那也不会。经过两个月的工作&#xff0c;学习&#xff0c;努力的学习WMS&#xff0c;MES&#xff0c;GW等系统…

BZOJ 1827: [Usaco2010 Mar]gather 奶牛大集会 树形DP

[Usaco2010 Mar]gather 奶牛大集会 Bessie正在计划一年一度的奶牛大集会&#xff0c;来自全国各地的奶牛将来参加这一次集会。当然&#xff0c;她会选择最方便的地点来举办这次集会。每个奶牛居住在 N(1<N<100,000) 个农场中的一个&#xff0c;这些农场由N-1条道路连接&a…

关于uboot的简介——uboot对Flash与DDR的管理

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 1、uboot阶段对Flash的分区 所谓分区&#xff0c;即对存储设备进行分块管理。 PC机等产品中&#xff0c;整个硬盘由操作系统统一管理&#xff0c;其使用文件系统帮我们管理硬盘空间&#xff0c;从而…

EF部署

2019独角兽企业重金招聘Python工程师标准>>> 部署 当应用程序使用EF后&#xff0c;可以通过Visual Studio来进行部署&#xff0c;即将数据库部署到真实环境中&#xff0c;可以作为正式上线使用环境。在进行部署前&#xff0c;我们也需要先做一些先前准备工作&#x…