标签:digit 579C int 代码 十进制 while printf 存疑 sum
题目:http://codeup.cn/problem.php?cid=100000579&pid=2
正确代码(已测验)看不懂memcpy0
#include <cstdio>
int main() {
char s[32]; //将十进制字符串转换为倒排的二进制字符串, 需模拟多次数字取余和除法
while (gets(s)) {
char nums[100] = {};
int numsSize = 0, sum = 1; //全十进制字符串
while (sum) { //当十进制字符还未除完时继续循环
sum = 0; //每一次十进制字符串除以2都恢复0
for (int i = 0; s[i]; i++) {
int digit = s[i] - '0';
int x = digit / 2;
sum += x;
if (s[i + 1]) {
s[i + 1] += (digit % 2 * 10);
} else {
nums[numsSize++] = digit % 2 + '0'; //从低位向高位存入取余的字符
}
s[i] = x + '0'; //一位字符的变化
}
}
for (int k = numsSize - 1; k >= 0; k--) {
printf("%c", nums[k]);
}
printf("\n");
}
return 0;
}
我的代码比较简单,但不能通过
#include<stdio.h>
int main(){
long long int a;
while(scanf("%d",&a)!=EOF){
int y[100]={0},num=0;
do{
y[num++]=a%2;
a/=2;
}while(a!=0);
int i=0;
for(i=num-1;i>=0;i--){
printf("%d",y[i]);
}
printf("\n");
}
return 0;
}
标签:digit,579C,int,代码,十进制,while,printf,存疑,sum 来源: https://blog.csdn.net/weixin_45547419/article/details/113827918
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。