日韩性视频-久久久蜜桃-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ò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 中文字幕av免费观看 | 中文字幕一区视频 | 91丨porny丨海角社区 | 特级西西444www高清大视频 | 牛牛av国产一区二区 | 午夜av网址 | 国产精品成人aaaaa网站 | 欧美一区不卡 | 国产高潮国产高潮久久久91 | 欧美俄罗斯乱妇 | 91麻豆精品久久久久蜜臀 | 人人妻人人澡人人爽国产一区 | 欧州一区 | 狠狠爱婷婷 | 欧美特一级 | 亚洲欧美一区二区三区四区五区 | 色人阁网站 | 日韩精品久久久久 | 久久刺激 | 一个人看的www视频在线观看 | 91麻豆精品一二三区在线 | av天堂一区二区三区 | 国产好片无限资源 | 91sao| 综合网伊人 | 亚洲一区二区三区高清在线 | 亚洲一区在线免费观看 | av在线免播放器 | 日日日干 | 殴美黄色大片 | 欧美性黄色 | 国产欧美一区二区三区白浆喷水 | 人妖一区| 777亚洲| 日韩欧美高清一区 | 久久国产美女视频 | 欧洲成人综合 | 操干网 | 可以在线观看的黄色 | 一级黄色片网址 | 国产777 | av直播在线观看 | 久久久精彩视频 | 国产一精品一aⅴ一免费 | 久久国产二区 | 成人一区二区精品 | 老司机黄色影院 | 亚洲4438| 性生活视频播放 | 韩国一区二区三区视频 | 亚洲伦理视频 | 国产69精品一区二区 | 激情偷乱人成视频在线观看 | 中文字幕av网址 | 久久青青草原亚洲av无码麻豆 | 在线看日韩av | www.欧美成人 | 亚洲天堂视频网站 | 激情综合站 | 精品一区二区视频 | 亚洲av无一区二区三区怡春院 | 日韩高清片 | 欧美亚洲精品在线观看 | 九色tv| 亚洲成人麻豆 | 一区二区三区福利 | 日韩特级黄色片 | 亚洲午夜久久久 | 男人的天堂中文字幕 | 屁股夹体温计调教play | 欧美99视频 | 久青草资源福利视频 | 成人免费做受小说 | 青青草免费观看 | 中文视频一区 | 天天干网| 狠狠一区二区 | 日韩中文字幕亚洲 | 五月婷婷视频在线观看 | 久草成人在线视频 | 亚洲国产日韩在线观看 | 韩日精品中文字幕 | 国产视频手机在线观看 | 邻居校草天天肉我h1v1 | 国产精品三级在线观看无码 | 噜噜噜在线 | 国产五月天婷婷 | 一区二区免费视频 | 先锋影音一区二区三区 | 无码aⅴ精品一区二区三区浪潮 | 性色av一区二区三区红粉影视 | 国产精品天天狠天天看 | 国产美女主播视频 | www.亚洲天堂.com | 欧美日韩一区二区三区不卡视频 | 中文字幕av有码 | 色婷婷视频在线观看 | 污污的网站在线免费观看 | 午夜男人网 |