微软面试题:有100万个数字(1到9),其中只有1个数字重复2次,如何快速找出该数字

/*******************************************************************************
文 件 名 : test100.cpp
实现功能 : 微软面试题:有100万个数字(1到9),其中只有1个数字重复2次,如何快速找出该数字补充下题目 意思:我这里每个数字 都是个阿拉伯数字,是1位的,是1到9之间的但是有1百万个这样的数字 比如 12345678912 是11个这样的数字
实现思路 : 定义9个数组,记录1-9的出现的数字做标记,出现一次则,对应数组加1,超过2次,在下次循环直接结束,这样一共直到记录8个数字后,直接打印第9个数字,就是一共只会出现2次的数字了
作    者 : jernymy
版    权 : <Copyright(C) ... jernymy.>
日    期 : 2011-07-28
版    本 : V1.0
*******************************************************************************/#include "stdio.h"
#include "stdlib.h"  // srand
#include "time.h"    // time
#include "string.h"  // memset// 最大的数据是100万, 1000000
#define MAX_NUM  1000*1000// 出现频率的个数
#define OVER_VAR  2// 记录1-9这几个数字出现的次数,是否出现超过2次,
// 如果超过2次可以不用判断,初始化为0
unsigned char g_abyNumAry[10];// 记录总共出现超过3次的数字的个数,当超过7个时,即为8时。
// 则可以直接打印出没有出现超过2次的那个数字,就一定是公出现2次的数字了。
unsigned char g_nCount = 0;int main(void)
{int nIdx;int nData;time_t nCurTime; srand(time(&nCurTime));memset(g_abyNumAry, 0, sizeof(g_abyNumAry));for (nIdx = 0; nIdx < MAX_NUM; nIdx++){nData = rand()%9 + 1; // 随机数从1到9,测试专用,jernymy from 1-9printf("%d ", nData); // 打印该随机数字// 此数字出现次数大于2次,则退出次循环if (g_abyNumAry[nData] > OVER_VAR){continue;}// 此数字出现1次,在大于2次时,就对总个数加1if (++g_abyNumAry[nData] > OVER_VAR){g_nCount++;}// 当有8个数字出现的个数均超过2次,// 那么剩下的那个数字一定就是要求的了if (g_nCount == 8){printf("\nfound only 2 num: ");for (nIdx = 1; nIdx < 10; nIdx++){if (g_abyNumAry[nIdx] < (OVER_VAR+1)){// jernymy 此数就是我们要找的那个了printf("%d\n", nIdx);}}break;}    }return 0;
}


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

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

相关文章

电影推荐之《哈利·波特与火焰杯》 隐私策略(Privacy policy)

1.隐私政策涵盖您对本应用的使用。 2.电影推荐之《哈利波特与火焰杯》不会收集、存储、分享您的任何个人信息或者与您的设备相关的信息。我们不会收集任何统计数据和分析数据&#xff0c;也不会跟踪用户的行为。转载于:https://www.cnblogs.com/zhhabo/p/3749602.html

Vh和Vw的简介和使用

Vw:视区宽度百分值 Vh:视区高度百分值 Vmin:取Vw或Vh中较小的那一个 Vmax:取Vw或Vh中较大的那一个 1.视区:是指浏览器内部的可视区域大小&#xff0c;即window.innerWidth/window.innerHeight大小&#xff0c;不包含任务栏标题栏以及底部工具栏的浏览器区域大小 2.场景之元…

处理后台返回文本带空格和换行页面不显示断句的问题

有时候接口返回文本数据是空格分开或者手动换行分开的&#xff0c;在页面上显示成一堆&#xff0c;只要在该节点上加上css 文本段落换行 white-space: pre-wrap;

江民杀毒软件KV网络版反病毒整体解决方案──金融行业

江民杀毒软件KV网络版反病毒整体解决方案──金融行业江民杀毒软件KV网络版反病毒整体解决方案──金融行业 金融行业是对信息化要求程度极高的行业。它需要一个高效、安全的网络环境来保证信息处理系统能正常有效运行。但随着信息化的应用面越来越广&#xff0c;信息安全…

Linux和Windows下查看、设置环境变量的比较

[一]查看环境变量&#xff1a; 1.windows 查看所有的变量&#xff1a;set 范例&#xff1a;>set 查看某个变量的值&#xff1a;set 环境变量名 范例&#xff1a; >set JAVA_HOME JAVA_HOMED:\jdk 2.linux 查看所有的变量&#xff1a;export 范例&#xff1a;export 查看某…

2014/5/25 多校

A: 1 #include<iostream>2 #include<stdio.h>3 #include<string.h>4 #include<set>5 #define maxn 58*3000006 using namespace std;7 8 set<int>S;9 int Enum0,score[maxn],son[maxn][26],l[maxn];10 bool flag[maxn];//标记是否打星11 int to…

margin:auto实现绝对定位元素的水平垂直居中

1.绝对定位元素的居中实现的一般方法 兼容性不错的主流用法是&#xff1a; 但&#xff0c;这种方法有一个很明显的不足&#xff0c;就是需要提前知道元素的尺寸。否则margin负值的调整无法精确。此时&#xff0c;往往要借助JS获得。 CSS3的兴起&#xff0c;使得有了更好的…

swiper 滑动出现闪白

滑动swiper时&#xff0c;swiper里面的元素会发生闪白的情况。 解决方法&#xff1a;给外部元素的父标css套一个&#xff08;swiper-container&#xff09; .swiper-container{transform:translate3d(0,0,0); }闪动元素/子元素&#xff08;swiper-slide&#xff09; .swiper…

MCSE2003学习之一

MCSE2003之2276&#xff1a;实现2003网络结构&#xff0c;网络主机TCP/IP协议的结构一&#xff1a;OSI模型计算机网络的形成促使网络协议的成熟。IBM在1974年提出了SNA网络协议二&#xff1a;分层模型的网络体系1&#xff1a;OSI/RM开放系统互联ApplicationPresentationSession…

Linux和windows中的换行符差异问题 LINUX的换行符在Windows记事本打开不换行或出现黑点

http://hi.baidu.com/mayongl7/blog/item/06e61af7c719053a730eec4d.html LINUX的换行符在Windows记事本打开不换行或出现黑点 是由于Linux和windows中的换行符差异问题造成的。 首先来看回车符号和换行符号产生背景 关于“回车”&#xff08;carriage return&#xff09;和“换…

x:Name与Name区别

x:Name与Name有两个不同点&#xff1a; 1、x:Name是Xaml的标记特性&#xff0c;任何在Xaml中定义的元素&#xff0c;都可以使用x:Name来为元素指定名称。 Name是FrameworkElement定义的依赖项属性&#xff08;String类型&#xff09;&#xff0c;只有FrameworkElement的派生类才…

CSS的包裹性

什么是包裹性&#xff1f; 包裹性就是父元素的宽度会收缩到和内部元素宽度一样。 哪些元素具有包裹性&#xff1f; 就我已知的有&#xff1a;absolute&#xff0c;fixed&#xff0c;float&#xff0c;inline-block&#xff0c;inline-flex&#xff0c;table-cell等等 应用场…

vue监听滚动开始与结束

data{ oldScrollTop: 0, //记录上一次滚动结束后的滚动距离 scrollTop: 0 ,// 记录当前的滚动距离 }watch: {scrollTop(newValue, oldValue) {setTimeout(() > {if(newValue window.scrollY) { //延时执行后当newValue等于window.scrollY&#xff0c;代表滚动结束console.l…

Pro*C 中嵌入pl/sql块

From: http://blog.csdn.net/zistxym/article/details/5054066 /* 包含C头文件 */ #include <stdio.h> #include <string.h> #include <stdlib.h> /* 包含SQLCA头文件 */ EXEC SQL INCLUDE sqlca; EXEC SQL INCLUDE sqlda; int main() { EXEC SQL BEG…

程序员是一盏省油的灯

新太科技商业泄密事件&#xff0c;引发作者万千感慨&#xff0c;本文是《新太科技商业泄密事件背后的思考》系列之四。加班是程序员的家常便饭&#xff0c;八小时工作制几成笑谈&#xff0c;在软件公司的眼里&#xff0c;程序员只是一架会思考的机器&#xff0c;是一盏省油的灯…

[译]第三章:什么是组织结构

组织结构有这自己的特性&#xff0c;一方面结构的作用是保持稳定&#xff0c;只有稳定的结构才可能产生效率&#xff0c;但是发展又需要结构变化&#xff0c;只有变化的结构才会带来发展&#xff1b;&#xff08;一&#xff09;组织结构是自我约定的关系&#xff1a;&#xff0…

:after伪类+content内容清除浮动

1.简单说说content内容生成 content内容生成就是通过content属性生成内容 例如下面这个简单的例子&#xff1a; 此段样式的作用是在每个h2标签的前面添加文字“我是额外文字”。 2.:after伪类content 清除浮动的影响 有点经验的同行应该知道&#xff0c;一般不含包裹属性…

图片宽高自动适配

一些长宽比不同的图片适应盒子&#xff0c;我们往往用js获取图片宽高&#xff0c;得到宽高谁长&#xff0c;让长边100%。 其实用css就可以解决,这样无论长边是谁都能适配屏幕了 img{ max-width:100%&#xff1b; max-height:100%; }