1. 程式人生 > >進制轉換及字符分割

進制轉換及字符分割

num strlen pac end col for ace std pre

技術分享圖片技術分享圖片

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
using namespace std;

int main()
{
    char str[100000];
    char *s;
    cin >> str;
    char *ptr;
    char *p;
    char fuhao[1000];
    int k=0;
    fuhao[0]=+;
    k++;
        for(int i=0; i<strlen(str); i++)
    {
        
if(str[i]==-||str[i]==+) fuhao[k++]=str[i]; } ptr=strtok(str, "-+"); long long ans=0; //cout << k << endl; int j=0; while (ptr != NULL) { long int num=0; s=ptr; //cout << s << endl; if(s[0]==0&&s[1
]==x) { char s1[1000]; for(int i=2; i<strlen(s); i++) s1[i-2]=s[i]; num=strtol(s,NULL,16); // cout << num << " 16" << endl; } else if(s[0]==0) { char s1[1000]; for(int
i=1; i<strlen(s); i++) s1[i-1]=s[i]; num=strtol(s,NULL,8); // cout << num << " 8" << endl; } else { num=strtol(s,NULL,10); //cout << num << " 10" << endl; } if(fuhao[j]==+) { ans+=num; //cout << num << " " << fuhao[j] << endl; } else if(fuhao[j]==-) { ans-=num; //cout << num << " " << fuhao[j] << endl; } j++; //cout << ans << endl; //printf("ptr=%s\n", ptr); ptr = strtok(NULL, "-+"); } cout << ans << endl; return 0; }

進制轉換及字符分割