After debugging of code,following changes you should do with your code..
- declare
int j = 0
.
- Also instead of
ris = intnum[8] * 2^0
use ris = intnum[7] * 1
since array index start with 0
in c.
- Also do same for
for(i = 6;i >= 0;i--)
and ris += intnum[i] * 2<<j
with left shift operator(<<
).
- Basically use of
getch()
is unnecessary and makes your program
non-portable,but if you want to use it,then I will suggest you to use
below codes..
For linux,use this code..
#include <stdio.h>
#include <termios.h>
#include <unistd.h>
int getch (void){
int ch;
struct termios oldt, newt;
tcgetattr(STDIN_FILENO, &oldt);
newt = oldt;
newt.c_lflag &= ~(ICANON|ECHO);
tcsetattr(STDIN_FILENO, TCSANOW, &newt);
ch = getchar();
tcsetattr(STDIN_FILENO, TCSANOW, &oldt);
return ch;
}
int main() {
int intnum[8], i = 0, ris,j = 0;
char charnum;
for (i = 0; i < 8; i++) {
charnum = getch();
intnum[i] = (charnum-'0');
}
ris = intnum[7] * 1;
for (i = 6; i >= 0; i--) {
ris += (intnum[i] * 2<<j);
j++;
}
printf("%d", ris);
getchar();
}
For windows,use this code..
#include <stdio.h>
#include <conio.h>
int main() {
int intnum[8], i = 0, ris,j = 0;
char charnum;
for (i = 0; i < 8; i++) {
charnum = getch();
intnum[i] = (charnum-'0');
}
ris = intnum[7] * 1;
for (i = 6; i >= 0; i--) {
ris += (intnum[i] * 2<<j);
j++;
}
printf("%d", ris);
getchar();
}