Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 1882 Accepted Submission(s): 741
1 #include <cstdio> 2 #include <queue> 3 using namespace std; 4 5 struct node{ 6 long long value,place; 7 }; 8 9 void bfs(long long n) 10 { 11 node tmp; 12 tmp.value = 0; 13 tmp.place = 1; 14 queue<node> q; 15 q.push(tmp); 16 bool findans = false; 17 long long ans = 0xffffffff; 18 while(!q.empty()){ 19 tmp = q.front(); 20 q.pop(); 21 node now; 22 now.place = tmp.place*10; 23 for(int i = 0; i<10; ++i){ 24 now.value = tmp.value+i*tmp.place; 25 if(now.value*now.value%now.place == n%now.place){ 26 if(!findans) 27 q.push(now); 28 if(now.value*now.value%now.place == n && now.value<ans){ 29 findans = true; 30 ans = now.value; 31 } 32 } 33 } 34 } 35 if(ans == 0xffffffff) 36 printf("None\n"); 37 else 38 printf("%I64d\n",ans); 39 } 40 41 int main() 42 { 43 int t; 44 scanf("%d",&t); 45 while(t--){ 46 long long n; 47 scanf("%I64d",&n); 48 bfs(n); 49 } 50 return 0; 51 }
上面的代码找到可行解之后需要进行比较找出最优解,我们可以对此进行优化,把queue改为priority_queue,让priority_queue帮我们完成这个工作,使得找到的第一个可行解便是满足题意的最优解。
1 #include <cstdio> 2 #include <queue> 3 using namespace std; 4 5 struct node{ 6 long long value,place; 7 bool operator < (const node& b)const 8 { 9 return value>b.value; 10 } 11 }; 12 13 void bfs(long long n) 14 { 15 node tmp; 16 tmp.value = 0; 17 tmp.place = 1; 18 priority_queue<node> q; 19 q.push(tmp); 20 while(!q.empty()){ 21 tmp = q.top(); 22 q.pop(); 23 if(tmp.value*tmp.value%tmp.place == n){ 24 printf("%I64d\n",tmp.value); 25 return ; 26 } 27 node now; 28 now.place = tmp.place*10; 29 for(int i = 0; i<10; ++i){ 30 now.value = tmp.value+i*tmp.place; 31 if(now.value*now.value%now.place == n%now.place){ 32 q.push(now); 33 } 34 } 35 } 36 printf("None\n"); 37 } 38 39 int main() 40 { 41 int t; 42 scanf("%d",&t); 43 while(t--){ 44 long long n; 45 scanf("%I64d",&n); 46 bfs(n); 47 } 48 return 0; 49 }
原文:http://www.cnblogs.com/inmoonlight/p/5245802.html