pat-1136. A Delayed Palindrome (20) 模拟
生活随笔
收集整理的這篇文章主要介紹了
pat-1136. A Delayed Palindrome (20) 模拟
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
本可以java大數(shù)就能搞定的問(wèn)題
當(dāng)時(shí)用java寫(xiě)完答案明明對(duì)了提交總是答案錯(cuò)誤
很是無(wú)語(yǔ)
題意
任給我們一個(gè)數(shù)
讓我們對(duì)這個(gè)數(shù)進(jìn)行翻轉(zhuǎn)相加
如果加和是個(gè)回文數(shù) 就找到了程序出口
如果不是繼續(xù)迭代
輸出過(guò)程 如果迭代10次沒(méi)有找到就輸出特定信息
分析
就是模擬高精度加法
場(chǎng)上沒(méi)想清楚為什么要那么加
兩個(gè)數(shù)相加只可能比原數(shù)多進(jìn)一位
完全可以用正序和逆序兩個(gè)數(shù)組里一加
不必管 低位高位 對(duì)齊的情況
因?yàn)槭且粋€(gè)數(shù)與自己的逆序相加 所以一定位數(shù)相同且從低位加還是從高位加結(jié)果相同
如果是不同數(shù)的加法或是乘法
我們需要從兩個(gè)數(shù)的最高位置 向低位運(yùn)算 因?yàn)楦呶粸樵瓟?shù)據(jù)的低位
所以最后再反向輸出
code
#include<bits/stdc++.h> using namespace std; char a[1010],b[1010]; bool check(char aa[]){int len = strlen(aa);for(int i=0;i<len-1-i;i++){if(aa[i]!=aa[len-1-i])return 0;}return 1; }//回文檢驗(yàn) int main() {gets(a);bool f=0;int c=0;while(!check(a)){if( c==10 ){printf("Not found in 10 iterations.");f=1;break;}int lena = strlen(a)-1,tag=0;for(int i=lena;i>=0;i--){b[tag++] = a[i];}//將原數(shù)逆序 b[tag] = '\0';printf("%s + %s",a,b);int i,y = 0;for(i=0;i<=lena;i++){//模擬加法int dig = (a[i]-'0')+(b[i]-'0')+y;a[i] = '0'+dig%10;if(dig>9)y=1;else y = 0;}if(y)a[i] = '0'+y,a[++i] = '\0';//余數(shù)處理else a[i] = '\0';//行尾結(jié)束控制i--;//找回重點(diǎn)for(int j=0;j<i-j;j++){//把順序換回來(lái)swap(a[j],a[i-j]);} printf(" = %s\n",a);c++;}if(!f)printf("%s is a palindromic number.",a);return 0; }總結(jié)
以上是生活随笔為你收集整理的pat-1136. A Delayed Palindrome (20) 模拟的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: div html表格样式,table 表
- 下一篇: 月球探测器中的计算机技术,月球探测器自主