Exe 2 —— 對數取1000的模……

來源:互聯網
上載者:User

#include <iostream>
using namespace std;
int num=0;   //全域對迭代的次數進行計數
int Q[100];  //每次迭代的結果所在數組
typedef struct
{
 int b;
 int s;
 int g;
} CType;

int quwei(int number,CType state[])
{
 number = number%1000;
 state[num].b = number/100;     //百位
 state[num].s = (number/10)%10; //十位
 state[num].g = number%10;      //個位
    int q=Q[num] = state[num].b*state[num].b*state[num].b+state[num].s*state[num].s+state[num].g;
 return q;
}

bool confilict(int Q[],int q)
{
 for(int i=0;i<num-1;i++)
 {
  if(q==Q[i])
   return true;
 }
 return false;
}

int main()
{
 int q=0;
 CType state[100];
 int number;
 char c='y';
    while(c=='y')
 {
  cout<<endl<<"請輸入一個整數:";
  cin>>number;
  q = quwei(number,state);  //得到Q[0]
  num++;
  while(!confilict(Q,q))
  {
   q = quwei(q,state);
   num++;
  }
  cout<<"迭代的次數是:"<<num-1<<endl;
  cout<<"每次迭代的中間結果是:"<<endl;
  for(int j=0;j<num-1;j++)
   cout<<"Q["<<j<<"]"<<":"<<'/t'<<Q[j]<<endl;
  cout<<"再來一次: y/n?"<<endl;
  num = 0;
  cin>>c;
 }
 return 0;
}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.