使用 C 语言程序打印仅包含数字 0 和 1 且其和为 N 的数字。


给定一个整数 n,任务是打印仅由 0 和 1 组成的数字,并且它们的和等于整数 n。

仅包含零和一的数字是 1、10、11,因此我们必须打印所有可以相加形成等于 n 的和的数字。

例如,如果我们输入 n = 31,则答案可以是 10+10+11 或 10+10+10+1。

示例

Input: 31
Output:10 10 10 1

算法

int findNumbers(int n)
START
STEP 1: DECLARE AND ASSIGN VARAIBALES m = n % 10, a = n
STEP 2: LOOP WHILE a>0
   IF a/10 > 0 && a > 20 THEN,
      SUBTARCT 10 FROM a AND STORE BACK IT IN a
      PRINT "10 "
   ELSE IF a-11 == 0 THEN,
      SUBTRACT 11 FROM a AND STORE
      BACK IN a
      PRINT "11 "
   ELSE
      PRINT "1 "
      DECREMENT a BY 1
   END IF
END LOOP
STOP

示例

#include <stdio.h>
// Function to count the numbers
int findNumbers(int n){
   int m = n % 10, a = n;
   while(a>0){
      if( a/10 > 0 && a > 20 ){
         a = a-10;
         printf("10 ");
      }
      else if(a-11 == 0 ){
         a = a-11;
         printf("11 ");
      }
      else{
         printf("1 ");
         a--;
      }
   }
}
// Driver code
int main(){
   int N = 35;
   findNumbers(N);
   return 0;
}

输出

如果我们运行上述程序,它将生成以下输出

10 10 1 1 1 1 11

更新于: 2019年8月22日

264 次查看

开启你的 职业生涯

通过完成课程获得认证

开始学习
广告