結果

問題 No.193 筒の数式
ユーザー kusukusu0511kusukusu0511
提出日時 2015-04-30 23:41:59
言語 C++11
(gcc 11.4.0)
結果
AC  
実行時間 2 ms / 1,000 ms
コード長 1,016 bytes
コンパイル時間 1,132 ms
コンパイル使用メモリ 61,116 KB
実行使用メモリ 4,384 KB
最終ジャッジ日時 2023-09-19 04:45:10
合計ジャッジ時間 2,462 ms
ジャッジサーバーID
(参考情報)
judge14 / judge12
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
4,376 KB
testcase_01 AC 2 ms
4,376 KB
testcase_02 AC 2 ms
4,380 KB
testcase_03 AC 2 ms
4,384 KB
testcase_04 AC 1 ms
4,380 KB
testcase_05 AC 2 ms
4,380 KB
testcase_06 AC 1 ms
4,380 KB
testcase_07 AC 2 ms
4,384 KB
testcase_08 AC 2 ms
4,380 KB
testcase_09 AC 1 ms
4,376 KB
testcase_10 AC 1 ms
4,380 KB
testcase_11 AC 2 ms
4,380 KB
testcase_12 AC 2 ms
4,376 KB
testcase_13 AC 1 ms
4,384 KB
testcase_14 AC 2 ms
4,376 KB
testcase_15 AC 1 ms
4,376 KB
testcase_16 AC 2 ms
4,380 KB
testcase_17 AC 1 ms
4,376 KB
testcase_18 AC 2 ms
4,380 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <string.h>
#include <algorithm>

int main(void){
	int a,b,c;
	char s[50];
	char s1[50]="";
	std::string s2;
	int total,cnt;
	int max=-100000000;

	std::cin>>s;
	
	for(int i=0; i<strlen(s); i++){

		for(int k=i,a=0; a<strlen(s); a++,k++){
			k%=strlen(s);
			s1[a]=s[k];
		}
		
		if(s1[0]!='+' && s1[0]!='-' && s1[strlen(s)-1]!='+' && s1[strlen(s)-1]!='-'){
		
			b=0;
			while(s1[b]>='0' && s1[b]<='9'){
				s2+=s1[b];
				b++;
			}
			b--;

			total= std::atoi(s2.c_str());
			s2="";

			for(int k=b; k<strlen(s1); k++){
				
				

				if(s1[k]=='+'){
					k++;
					while(s1[k]>='0' && s1[k]<='9'){
						s2+=s1[k];
						k++;
					}
					k--;
					c=std::atoi(s2.c_str());
					
					s2="";
					total+=c;
				}
		
				else if(s1[k]=='-'){
					k++;
					while(s1[k]>='0' && s1[k]<='9'){
						s2+=s1[k];
						k++;
					}
					k--;
					c=std::atoi(s2.c_str());
					s2="";
					total-=c;
				}	
				
					
			}

			max=std::max(max,total);
		}		
	}
	
	std::cout<<max<<std::endl;	

}
0