2019年12月26日 星期四

P2T補充


/*
P2T 12/13-2   陣列的練習
給一個正整數 n {1<n<10^6} ,接著給n-1個 1~n的編號,請問少了哪一個?
例如 5 4 1 2 3 ,後面4個編號中少了5
     6 5 6 1 3 2 ,後面5個編號中少了4
*/
#include <iostream>
using namespace std;
int a[1000001];  // 0~1000000
int main()
{
    int i,j,k,n;
    while( cin >> n )
    {
       for(i=1; i<=n; ++i)
          a[i]=0;       
       for(i=1; i<n; ++i)
       {
          cin >> k;
          a[k] = 1;         
       }
       for(i=1; i<=n; ++i)
       {
          if( !a[i])
          {
              cout << i << endl;
              break;    
          }
       }
    }
  return 0;
}



/*
P2T 12/27-1   陣列的練習
給一個正整數 n {1<n<10^4} ,接著給n個相異編號{ 1~10^9}
再n-1個編號,請問少了哪一個?  6 1 12 23 34 56 67  56 67 1 34 23  少了12 
例如 5 66666666 123456 234567 33 777777 
            66666666 123456 234567 777777,後面4個編號中少了33
     6 543 612 93333333 93333336 2345 111 
        543 612 933336 2345 111  後面5個編號中少了93333333
*/
#include <iostream>
using namespace std;
int a[100000001]; //a[100000001];  // 0~1000000000 記憶體容量 不允許
int main()
{
    int i,k,n,m; 
    while( cin >> n )
    {
       for(i=1; i<=n; ++i)
          a[i]=0;       
       for(i=1; i<=n; ++i)
       {
          cin >> k;
          a[k] = 1;         
       }
       m=0;
       for(i=1; i<n; ++i)
       {
          cin >> k;
          if(k>m) m=k;  //最大的數 
          a[k] = 0;      
       }
       
       for(i=1; i<=m; ++i)
       {
          if( a[i])
          {
              cout << i << endl;
              break;    
          }
       }
    }
  return 0;
}


/*  P2T 12/27-2   陣列的應用 + map
C++ STL
vector 
set 
map
... 
P2T 12/27-2   陣列的練習
給一個正整數 n {1<n<10^4} ,接著給n個相異編號{ 1~10^9},
再n-1個編號,請問少了哪一個?  6 1 12 23 34 56 67  56 67 1 34 23  少了12 
例如 5 666666666 123456789 234567891 33 7777777 
      a[0]        a[1]     a[2]      a[3]   a[4]  
       666666666 123456789 234567891 7777777,後面4個編號中少了33
     6 543 612 933333333 933333336 2345 111  
        933333336 2345 111  543 612  , 
後面5個編號中少了933333333
*/
#include <iostream>
#include <map>  // 字典類
#include <cstring> // memset
using namespace std;
map<int,int> mp;  //某個名稱或數字(可能很大) 對應至序號 
int mpcnt;
int a[10000];
bool b[10000];
int main()
{
   int n,i,j;
   while( cin >> n )
   {
      mp.clear(); //mp清空
      memset(b,0,sizeof(b)); // b全清為 0 
      for(i=0; i<n; ++i)
      {
         cin >> a[i];         
         mp[ a[i] ] = i;
      }  
      // 只回來 n-1 個,少了哪一個 
      for(i=0; i<n-1; ++i)
      {
         cin >> k;
         j = mp[ k ]  //直接傳回原序號 
         b[j]=1;
      }  
      for(i=0; i<n; ++i)
      {
         if( b[i] == 0 ) //印出未回的
         {
           cout << a[i] << endl; 
           break;
         }
      }  
           
   }
  system("pause");
  return 0;
}


0 意見:

張貼留言