★ 하단의 문제에 따라 제가 다음처럼 코딩을 해보았는데요, 에러는 없는데 빨간부분의 경고가 뜨고 실행도 안되요
해결좀 할 수 있을까요?
문제) 16비트 부호 없는 정수의 값을 이동연산자를 사용하여 우로 1비트 이동시키면 최하위 비트값이 제거된다. 이때 제거되는 최하위 비트의 값을 최상위 비트에 채워 넣는 우로테이션(right rotation)기능의 프로그램을 작성하시오.
#include<stdio.h> #include<conio.h>
int main(void) { unsigned int a,b,c,d,n,MAX;
clrscr();
printf("Enter positive decimal number : "); // 양의 변수 a 에 10진수를 입력합니다. scanf("%d", &a);
printf("Enter shift number : "); // 내가 시프트 할 만큼의 값을 입력합니다
scanf("%d", &MAX);
d=a;
for(n=1;n=MAX;n++) <--- possibly incorrect assignment 이부분 에러좀 안나게끔 할 수 있나요? //a를 16진수의 형태에서 MAX만큼 우로 시프트 하는데
{ a=a>>n; b=0; c=a; if((a&0x1)==0x1) /* 한 비트씩 우로 시프트할 때 마다 10진수를 입력받은 a의 16진수값의 우측끝 비트수가 0인지 1인지를 확인해서 */ { b=2^(16-n); //1일때 좌측끝으로 붙여 넣어줍니다. 우측 끝에서 밀린 수는 소멸되고요..
c=c+b; /*위의 것을 시프트수만큼 수행하는데 우측 끝으로 밀린 수가 1이 아닌 zero 일 때도 있죠*/
} else c=a; // 우측 끝 비트수가 0일 때에도 좌측 끝으로 붙여 넣어줍니다. } printf("The number %d has been shifted by %d from initial number",c,MAX,d); /* 최초의 수가 시프트 했을 때 16진수의 우측끝에서 소멸된 0 혹은 1이 시프트한 만큼 이동해서 좌측 끝에 붙는다는 것을 표출합니다.*/ getch();
return 0;
}
|