[解決済み] シフトを使用しないTMaxの求め方
2022-02-13 11:12:02
質問
ONLYを使用する
! ~ & ^ | +
32ビット数がTMaxかどうかを調べるにはどうしたらいいですか?
TMaxは最大、2の補数です。
これまでの私の考えは
int isTMax(int x)
{
int y = 0;
x = ~x;
y = x + x;
return !y;
}
しかし、TMaxのプロパティでTMaxを返してくれるようなものは思いつきません。例えば、tmaxを自分自身に足すと、他のすべての整数と比較してユニークになります。
実際の問題はこちらです。
/*
* isTMax - return 1 if x is the maximum, two's complement number,
* and 0 return otherwise.
* Legal ops: ! ~ & ^ | +
* Max ops: 10
* Rating: 1
*/
int isTMax(int x) {
int y = 0;
x = ~x;
y = x + x;
return !y;
}
intは32ビットなので、符号付きの最大値は0x7FFFFFFでしょう。
どのように解決するのですか?
こんな感じでしょうか? 0x7FFFFFFF は正符号付き 32 ビット 2 の補数の最大値です。
int isTMax(int x){
return !(x ^ 0x7FFFFFFF);
}
よくわからないのですが、unsignedにキャストしないと動作しないかもしれません。
関連
-
[解決済み】デバッグアサーションに失敗しました。C++のベクトル添え字が範囲外
-
[解決済み】#include<iostream>は存在するのですが、「識別子 "cout "は未定義です」というエラーが出ます。なぜですか?
-
[解決済み】'std::cout'への未定義の参照
-
[解決済み] 文字列の単語を反復処理するにはどうすればよいですか?
-
[解決済み] using namespace std;」はなぜバッドプラクティスだと言われるのですか?
-
[解決済み] 1ビットのセット、クリア、トグルはどのように行うのですか?
-
[解決済み] 32ビット整数のセットビットの数を数えるには?
-
[解決済み】ビットシフト(bit-shift)演算子とは、どのようなもので、どのように機能するのですか?
-
[解決済み】数値を2進数で表示(coutを使用)するには?
-
[解決済み] C# intからbyte[]への変換
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】コンストラクターでのエラー:識別子を期待されますか?
-
[解決済み】LLVMで暗黙のうちに削除されたコピーコンストラクタの呼び出し
-
[解決済み】C++コンパイルタイムエラー:数値定数の前に期待される識別子
-
[解決済み】IntelliSense:オブジェクトに、メンバー関数と互換性のない型修飾子がある
-
[解決済み】cc1plus:エラー:g++で認識されないコマンドラインオプション"-std=c++11"
-
[解決済み] [Solved] インクルードファイルが開けません。'stdio.h' - Visual Studio Community 2017 - C++ Error
-
[解決済み】1つ以上の多重定義されたシンボルが見つかる
-
[解決済み] 数値定数の前にunqualified-idを付けて、数値を定義することを期待する。
-
[解決済み】VC++の致命的なエラーLNK1168:書き込みのためにfilename.exeを開くことができません。
-
[解決済み】変数やフィールドがvoid宣言されている