どのように私はscanf関数を使用してCのint対オペレータを検出していますか?
-
23-09-2019 - |
質問
2
2+
4
今の私のscanfのように文字列のみで最初の文字を見て、私はこれを行うことができます。
2
2
+
4
私はまた、浮動小数点モード対整数のためのオプションを追加しようとしています。 (例:「I」が入力された場合、その逆浮動小数点副で動作する。)
#include <stdio.h>
#include <stdlib.h>
#define MAX 100
int *p;
int *tos;
int *bos;
void push(int i);
int pop(void);
int main (void)
{
int a, b;
//float c, d;
char s[80];
//char op; //declare string of 80 chars
p = (int *) malloc(MAX*sizeof(int)); //get stack memory
if (!p){
printf("Allocation Failure\n");
exit(1);
}
tos = p;
bos = p + MAX-1;
printf("\nRPN Calculator\n");
printf("Enter 'i' for integer mode\n");
printf("Enter 'f' for floating point mode\n");
printf("Enter 'q' to quit\n");
do {
printf("> ");
// gets(s);
// scanf("%s", s); //read integer
scanf("%s", s);
// switch (*s) {
switch(*s) {
case 'i':
printf("(Integer Mode)\n");
break;
case 'f':
printf("(Floating Point Mode)\n");
break;
case '+':
a = pop();
b = pop();
printf("%d\n", a+b);
push(a+b);
break;
case '-':
a = pop();
b = pop();
printf("%d\n", b-a);
push(b-a);
break;
case '*':
a = pop();
b = pop();
printf("%d\n", a*b);
push(a*b);
break;
case '/':
a = pop();
b = pop();
if(a == 0){
printf("Cannot divide by zero\n");
break;
}
printf("%d\n", b/a);
push(b/a);
break;
case '.':
a = pop();
push(a);
printf("Current value on top of stack: %d\n", a);
break;
default:
push(atoi(s));
}
} while (*s != 'q');
return 0;
}
// Put an element on the stack
void push (int i)
{
if (p > bos){
printf("Stack Full\n");
return;
}
*p = i;
p++;
}
// Get the element from the top of the stack
int pop (void)
{
p--;
if(p < 0) {
printf("Stack Underflow\n");
return 0;
}
return *p;
}
解決
あなたのscanf
は、文字列全体を読み込みます。それは+
で2+
最初の文字とミスによって判断し、次のスイッチです。
あなたはstrtol
機能を使用することができ、それを改善するため。それはあなたに、文字列とリターンのうち、整数が終了した場所整数を解析します - 。それはまだ文字列の終わりではない場合は、そこにオペレータがあるかもしれませんが、
浮動小数点数のための同様の機能がstrtod
である。
ここではあなたの例に適用strtol
のいくつかのサンプルコードがあります:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
char* input = "25+";
char* endptr;
int val = strtol(input, &endptr, 10);
if (*endptr == '\0')
{
printf("Got only the integer: %d\n", val);
}
else
{
printf("Got an integer %d\n", val);
printf("Leftover: %s\n", endptr);
}
return 0;
}
他のヒント
私は完全にあなたの質問を理解していますが、このような文字列を反復処理することができれば、私はわからない。
for(i = 0; i < strlen(s); i++)
{
// Here comes your switch section like this
switch(s[i]) {
.....
}
}
string.hのを含めることも忘れないでください。
私は本当にあなたのコードを理解していませんでした。
は、ユーザーがそれぞれの時間を1つの文字を入力することが予想される場合は、私は+を入力して1つの文字を意味し、あなたがcharの代わりに、単純な文字を使用する必要があります[]。あなたは、文字列を使用するふり場合、あなたはそれを受け取ると言っpzicoそれを解析する必要があります。 あなたはそのような何かを行うことができます。問題は、複数桁の数字の治療であることが、あなたがこの問題を解決することができ、少し考えてしまいます。私は試みを書きましたが、私はそれが仕事に行くのではないだと確信しています。
のprintf( "\ NRPN電卓\ N");
printf( "整数モードは 'I' を入力します\ N");
printf( "浮動小数点モードの 'F' を入力してください\ nは");
printf( "\ nで終了する 'Q' を入力してください");
scanf関数( "%のC"、S);
スイッチ(* S){
case 'i':
printf("(Integer Mode)\n");
break;
case 'f':
printf("(Floating Point Mode)\n");
break;
case 'q':
printf("Bye Bye\n");
return;
break;
} printf(「表現を1つの文字ごとに\ nと入力します。」);
DO {
scanf("%c", s);
switch(s) {
case '+':
a = pop();
b = pop();
printf("%d\n", a+b);
push(a+b);
break;
case '-':
a = pop();
b = pop();
printf("%d\n", b-a);
push(b-a);
break;
case '*':
a = pop();
b = pop();
printf("%d\n", a*b);
push(a*b);
break;
case '/':
a = pop();
b = pop();
if(a == 0){
printf("Cannot divide by zero\n");
break;
}
printf("%d\n", b/a);
push(b/a);
break;
case '.':
a = pop();
push(a);
printf("Current value on top of stack: %d\n", a);
break;
default:
a = pop()*10+atoi(s);
push(a);
}
}ながら(S = 'Q'!);
あなたのコード内のもう一つの問題は、あなたのポップ機能です。あなたがこのテストを行うにはしたくない:
もし(P <0){
printf( "スタックアンダーフロー\ N");
リターン0;
}
あなたはアドレスに到達するためにポインタを期待している0?
とにかく私はこれがあなたの宿題ではありません願っています。