除了十八层循环有没有更好的解法,想过用递归但却不知道怎么编 希望有人能教教我
1条回答 默认 最新
- 「已注销」 2022-03-17 09:18关注
#include<stdio.h> #include<stdlib.h> int a_array[18] = {57,71,87,97,99,101,103,113,114,115,128,129,131,137,147,156,163,186}; int result[18] = {0}; void recursive(int level,int sum) { if (17 < level) {return;} int i = 0 ; while (1) { int next_sum =sum - i * a_array[level]; if (next_sum > 0 ) { result[level] = i; recursive(level + 1, next_sum); } else if (next_sum == 0) { result[level] = i; // int j,sum=0; // for(j = 0 ; j < 18 ;j++) {printf("%d*%d +",result[j],a_array[j]);sum+=result[j]*a_array[j];} // printf("\n%d\n",sum); return; } else { return; } ++i; } } int main() { recursive(0,1000); }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 2无用