「アルゴリズムに関する注意事項」セクション2.3-C / C ++クイックスタート->構造コード分析の選択

「アルゴリズムノート」のセクション2.3-C / C ++クイックスタート->構造の選択

最初の質問:1つの変数で2次方程式の根を見つける例4-1

タイトルの説明
二次方程式ax2 + bx + c = 0のルートを見つけます。3つの係数a、b、およびcはキーボードによって入力され、aを0にすることはできませんが、b2-4ac> 0は保証されません。
プログラムに含まれる変数はdouble型です。スペースで区切られた1つの要素の2次方程式の3つの係数を
入力
し、2倍精度のダブルタイプの
出力
。2つのルートは次のように分岐によって出力されます(最後の新しい行に注意してください)
。r1=最初のルート
r2 = 2番目のルート
結果が出力されるとき、幅は小数点以下2桁を含む7桁。
方程式に実根がない場合は、次のように情報の行を出力します(最後の新しい行に注意してください):
実根なし!
サンプル入力コピー
1 2 3
サンプル出力コピー
実根なし!

#include <stdio.h>
#include <math.h>

int main() {
    
    
    double a, b, c, r1, r2;
    scanf("%lf%lf%lf", &a, &b, &c);
    double discriminant;
    discriminant = b * b - 4 * a * c;
    if (a) {
    
    
        if (discriminant >= 0) {
    
    
            r1 = (-b + sqrt(discriminant)) / (2 * a);
            r2 = (-b - sqrt(discriminant)) / (2 * a);
            printf("r1=%7.2f\nr2=%7.2f", r1, r2);
        } else {
    
    
            printf("No real roots!");
        }
    }
    return 0;
}

質問2:例4-2実際の値の比較と交換

タイトル説明
キーボードから2つの実数を入力し、代数値の降順で2つの数を出力します。スペースで区切って2つの実数を
入力
します。
出力
これらの2つの実数は、スペースで区切られた小さいものから大きいものへと出力され、前面に10進数、背面に大きい数値が表示されます。
小数点以下2桁を保持します。
最後に新行文字が出力されます。
サンプル入力コピー
3.6 -2.3
サンプル出力コピー
-2.30 3.60
三つ目は王様です

#include <stdio.h>

int main() {
    
    
    double a, b;
    scanf("%lf%lf", &a, &b);
    a > b ? printf("%.2f %.2f\n", b, a) : printf("%.2f %.2f\n", a, b);
    return 0;
}

わかりやすい

#include <stdio.h>
int main()
{
    
    
    double a,b;
    scanf("%lf%lf",&a,&b);
    if(a>b)
    {
    
    
        printf("%.2f %.2f\n",b,a);
    }
    else
    {
    
    
        printf("%.2f %.2f\n",a,b);
    }
    return 0;
}

3番目の質問:例4-3 3つの実際の値を比較して交換し、順番に出力する

タイトル説明
キーボードから3つの実数a、b、cを入力し、最小値を変数aに、最大値を変数cに、中間値を変数bに、小さいものから大きいものの順に比較交換して格納します。これらの3つの数値a、b、cを出力します。
最後にラインフィードが出力されます。
入力
入力は、3つの実数の
出力の
昇順で、3つの実出力のスペースで区切られ、最大値の後、中間のスペース、最小のフロントで区切られます。小数点以下2桁を保持します。
最後の新しい行に注意してください。
サンプル入力コピー
3 7 1
サンプル出力コピー
1.00 3.00 7.00

#include <stdio.h>

int main() {
    
    
    double a, b, c;
    scanf("%lf%lf%lf", &a, &b, &c);
    if (a > b) {
    
    
        if (b > c) {
    
    
            printf("%.2f %.2f %.2f", c, b, a);
        } else {
    
    
            if (a > c) {
    
    
                printf("%.2f %.2f %.2f", b, c, a);
            } else {
    
    
                printf("%.2f %.2f %.2f", b, a, c);
            }
        }
    } else {
    
    
        if (c > b) {
    
    
            printf("%.2f %.2f %.2f", a, b, c);
        } else {
    
    
            if (a > c) {
    
    
                printf("%.2f %.2f %.2f", c, a, b);
            } else {
    
    
                printf("%.2f %.2f %.2f", a, c, b);
            }
        }
    }
    return 0;
}

4番目の問題:演習4-43つの整数の最大値を見つける

タイトル説明
キーボード入力の整数a、b、cがあり、最大数を出力します。スペースで区切って3つの整数を
入力
します。3つの数値の最大値を
出力
し、最後に新しい行を追加します。
サンプル入力コピー
1 3 2
サンプル出力コピー
3は
別のかわいい三眼鏡

#include <stdio.h>

int main() {
    
    
    int a, b, c;
    scanf("%d%d%d", &a, &b, &c);
    a > b ? (a > c ? printf("%d", a) : printf("%d", c)) : (b > c ? printf("%d", b) : printf("%d", c));
    return 0;
}

わかりやすい

#include <stdio.h>

int main() {
    
    
    int a, b, c;
    scanf("%d%d%d", &a, &b, &c);
    if (a > b) {
    
    
        if (b > c) {
    
    
            printf("%d\n", a);
        } else {
    
    
            if (a > c)
                printf("%d\n", a);
            else
                printf("%d\n", c);
        }
    } else {
    
    
        if (b > c) {
    
    
            if (a > c)
                printf("%d\n", b);
            else
                printf("%d\n", b);
        } else {
    
    
            printf("%d\n", c);
        }
    }
    return 0;
}

5番目の質問:演習4-10-1ボーナスの計算

トピックの説明
会社が発行するボーナスは、利益手数料に基づいています。利益Iが100,000以下の場合、ボーナスは10%増加する可能性があります。利益が100,000元を超える場合、および利益が200,000元未満(100000 <I <= 20000)の場合、100,000元未満の部分は、10%の手数料(100,000を超える)の対象となります。 RMBの部分コミッション率は7.5%です。200000<I <= 400000の場合、200,000元未満の部分は上記の方法(以下と同じ)に従ってコミッションされ、200,000元を超える部分は5%でコミッションされます; 400000 <I <= 600000 RMBの場合、400,000 RMBを超える部分は3%の手数料がかかり、600000 <I <= 1000000の場合、600,000 RMBを超える部分は1.5%の手数料がかかり、I> 1000000元の場合、1000000元を超える部分は1%の手数料がかかります。
今月の利益Iをキーボードから出力し、発行すべきボーナスの数を見つければ、ボーナスはそのポイントまで正確です。
ifステートメントを使用して実装する必要があります。
入力
エンタープライズ利益、小数、倍精度倍精度
出力
発行されるボーナス数、小数点以下2桁を維持し、最後に折り返します。
サンプル入力コピー
1050
サンプル出力コピー
105.00

#include <stdio.h>

int main() {
    
    
    double profit, bonus;
    scanf("%lf", &profit);
    if (profit <= 100000)
        bonus = profit * 0.1;
    else if (profit <= 200000)
        bonus = (profit - 100000) * 0.075 + 10000;
    else if (profit <= 400000)
        bonus = (profit - 200000) * 0.05 + 7500 + 10000;
    else if (profit <= 600000)
        bonus = (profit - 400000) * 0.03 + 10000 + 7500 + 10000;
    else if (profit <= 1000000)
        bonus = (profit - 600000) * 0.015 + 6000 + 10000 + 7500 + 10000;
    else
        bonus = (profit - 1000000) * 0.01 + 3000 + 6000 + 10000 + 7500 + 10000;
    printf("%.2f", bonus);
    return 0;
}

ここに写真の説明を挿入

おすすめ

転載: blog.csdn.net/DoMoreSpeakLess/article/details/107722998