日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

真正的不重复数字实现,像人一样去编程

發(fā)布時(shí)間:2025/7/14 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 真正的不重复数字实现,像人一样去编程 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

題目要求如下:

如果一個(gè)數(shù)字十進(jìn)制表達(dá)時(shí),不存在連續(xù)兩位相同,則稱之為“不重復(fù)數(shù)”。例如,105、164和198都是“不重復(fù)數(shù)”,而11、100和122不是。實(shí)現(xiàn)一個(gè)函數(shù),用一個(gè)long類型( long類型數(shù)字A),實(shí)現(xiàn)返回大于A的最小“不重復(fù)數(shù)”。

看到兩個(gè)朋友在做這個(gè)算法題

趣味算法:返回不重復(fù)數(shù)的實(shí)現(xiàn)? 夏小冰

算法,一個(gè)永恒的話題,挑戰(zhàn)你的編程之美?winzheng

夏小冰的代碼,運(yùn)算時(shí)1122, 18, 21,123, 98都有正確結(jié)果,但是100011,121989999的答案是錯(cuò)的

winzheng的結(jié)果如下

A=1122, 18, 21,123, 98,100011,121989999

結(jié)果:1201,19,23,124,101,101010,123010101

看起來(lái)功能都是實(shí)現(xiàn)了

但是仔細(xì)看代碼他是把輸入的A不斷加1,并且判斷結(jié)果的數(shù)字是否符合要求?

//只要是一個(gè)人,就不會(huì)這么去做的(sorry,兄弟)
*其實(shí)我們?cè)诰幊痰臅r(shí)候更多的要從自身角度出發(fā)。從問(wèn)題的固有規(guī)律出發(fā),設(shè)想一個(gè)人是如何來(lái)解決這個(gè)問(wèn)題的。并且把解決問(wèn)題的步驟轉(zhuǎn)化為程序,就能寫(xiě)出比較好的算法了。

想想如果給一個(gè)人一個(gè)100位長(zhǎng)的數(shù)字,他會(huì)用這種不斷加1的辦法來(lái)解決問(wèn)題嗎?

《編程之美》

這個(gè)是winzheng的標(biāo)題,不過(guò)從他的代碼里只能感受到對(duì)CPU無(wú)情的蹂躪。

以至于

如果數(shù)據(jù)更大,例如:121989999991999,花了好幾分鐘也沒(méi)算出來(lái),這個(gè)時(shí)候真的需要考慮時(shí)間復(fù)雜度等問(wèn)題了。

解決這個(gè)問(wèn)題只要把計(jì)算機(jī)當(dāng)人看就可以了

1、將輸入數(shù)加1

2、人類會(huì)從最高位的下一位作為當(dāng)前位開(kāi)始逐位尋找相鄰的連續(xù)數(shù),如果沒(méi)有,則該數(shù)字就是目標(biāo)值

3、如果當(dāng)前位和前一位相同,把當(dāng)前位的數(shù)字加1

3.1 如果加1后導(dǎo)致進(jìn)位,則當(dāng)前位等于前一位,前一位加1,返回3.1

3.2 加1后不進(jìn)位,返回原始數(shù)字最高位到當(dāng)前位的數(shù)據(jù),后續(xù)拼接上“0101…”組成的剩余部分即可

3.3 進(jìn)位到最高位,則返回1,后續(xù)拼接上“0101…”組成的剩余部分即可

代碼如下

?

public static long GetNextNotDuplicatedValue4(long a)
??????? {
??????????? //原始數(shù)據(jù)轉(zhuǎn)換成數(shù)組
??????????? char[] arr = a.ToString().ToCharArray();
??????????? //從最高位的下一位作為當(dāng)前位開(kāi)始逐位尋找相鄰的連續(xù)數(shù)
??????????? for (int i = 1; i < arr.Length; i++)
??????????? {
??????????????? //如果相鄰兩位重復(fù)
??????????????? if (arr[i - 1] == arr[i])
??????????????? {
??????????????????? //如果當(dāng)前位和前一位相同
??????????????????? while (i > 0 && arr[i - 1] == arr[i])
??????????????????? {
??????????????????????? //把當(dāng)前位的數(shù)字加1
??????????????????????? arr[i] = (char)((arr[i] - 48 + 1) % 10 + 48);
??????????????????????? //如果加1后導(dǎo)致進(jìn)位
??????????????????????? while (i > 0 && arr[i] == '0')
??????????????????????? {
??????????????????????????? //前一位加1
??????????????????????????? arr[i - 1] = (char)((arr[i - 1] - 48 + 1) % 10+48);
??????????????????????????? //當(dāng)前位等于前一位
??????????????????????????? i--;
??????????????????????? }
??????????????????? }

??????????????????? //加1后不進(jìn)位(i != 0),返回原始數(shù)字最高位到當(dāng)前位的數(shù)據(jù),后續(xù)拼接上“0101…”組成的剩余部分即可
??????????????????? //進(jìn)位到最高位(i == 0),則返回1,后續(xù)拼接上“0101…”組成的剩余部分即可
??????????????????? string t = i == 0 ? "1" : new string(arr.TakeWhile((item, index) => index <= i).ToArray());
??????????????????? return long.Parse(t + makestring2(arr.Length - i-Math.Sign(i)*1));
??????????????? }
??????????? }
??????????? //如果沒(méi)有,則該數(shù)字就是目標(biāo)值
??????????? return a;
??????? }

static string makestring2(int i)
??????? {
??????????? StringBuilder s = new StringBuilder(i);
??????????? for (int j = 0; j < i; j++)
??????????? {
??????????????? s.Append(j % 2==0? "0" : "1");
??????????? }
??????????? return s.ToString(); ;
??????? }

?

運(yùn)行速度僅和A的位數(shù)部分相關(guān)

計(jì)算121989999991999也是瞬間的

總結(jié):

把計(jì)算機(jī)當(dāng)親兄弟來(lái)看待,雖然他傻得只會(huì)不知疲倦得做加法

另外:

算法絕不是書(shū)上學(xué)來(lái)的那幾種

環(huán)顧一下四周,想想人類是如何改變世界的,然后再讓計(jì)算機(jī)兄弟來(lái)幫忙

測(cè)試數(shù)據(jù)也是非常重要的一個(gè)東西

轉(zhuǎn)載于:https://www.cnblogs.com/Chinese-xu/archive/2009/09/05/1560905.html

總結(jié)

以上是生活随笔為你收集整理的真正的不重复数字实现,像人一样去编程的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲色视频 | 久久美 | 黄色aa大片 | 国产成人久久77777精品 | 日韩经典午夜福利发布 | 中文字幕一区二区三区乱码人妻 | 91不卡在线| va婷婷在线免费观看 | 亚洲欧美国产日韩精品 | 91免费 看片 | 日本a v在线播放 | 中文字幕女同女同女同 | 欧美亚洲综合网 | 日韩无码精品一区二区三区 | 亚洲美女毛片 | 久久精品一本 | 国产a视频免费观看 | 美女免费毛片 | 欧美一区二区国产 | 国模私拍一区二区 | 久久免费公开视频 | 国产一区二区三区四区五区六区 | 国产一区二区三区在线免费 | 午夜精品偷拍 | 男人网站在线观看 | a视频免费 | 国产精品96久久久久久 | 最新精品国产 | 葵司ssni-879在线播放 | 青草视频在线免费观看 | 欧美一区自拍 | 日韩不卡一二三区 | 国产精品麻豆视频 | 丁香啪啪综合成人亚洲 | 美国黄色一级大片 | 在线成人中文字幕 | 欧美日韩一区二区三区四区 | av免费网站在线观看 | 午夜剧场成人 | 国产精品免费av一区二区三区 | 久久图库 | 免费草逼视频 | 亚洲一区观看 | 在线观看的黄色网址 | 国产裸体视频网站 | 毛片1000部免费看 | 亚洲黄色网址 | 91在线观看免费 | a级黄视频 | 日本不卡一区二区三区在线观看 | 成人乱人乱一区二区三区一级视频 | 好男人在线视频www 亚洲福利国产 | 草在线| 18pao国产成视频永久免费 | 国产精品免费久久久久 | 综合色婷婷 | 色倩网站| 国产欧美视频一区二区三区 | 欧美理论视频 | 日韩精品xxx | 亚洲天堂影院在线观看 | 6090伦理| 国产精品久久久久一区二区 | 国产精品亚洲专区无码牛牛 | 性生交大片免费看l | 动漫美女被吸乳奶动漫视频 | 36d大奶 | 比利时xxxx性hd极品 | 黄色小说图片视频 | 一级香蕉视频在线观看 | 国产主播中文字幕 | 污污网站在线 | 艳妇乳肉豪妇荡乳av | 婷婷视频一区 | 青草青青视频 | 中文字幕电影一区二区 | 国产成人一区二区三区别 | 日韩国产专区 | 欧美超碰在线观看 | 亚洲欧美视频在线播放 | 国产av一区二区不卡 | 91中文字幕永久在线 | 成人综合社区 | 少妇又紧又色 | www.av网| 成人精品福利视频 | 91片黄在线观看 | 蜜臀av无码精品人妻色欲 | 精品成人无码一区二区三区 | 久久国产乱子伦精品 | 欧美浓毛大泬视频 | 超碰在线免费观看97 | 欧美日韩视频一区二区三区 | 久久精品网 | 欧美日韩久久精品 | 无码少妇一区二区 | 久久高清毛片 | 午夜久久久久久噜噜噜噜 | 午夜激情视频在线观看 |