C言語で対称二重三角形パターンを印刷する
行数を考慮すると、プログラムは最小限の複雑さで対称的な二重三角形パターンを印刷する必要があります。
例
Input: 5 Output: X X O X O X X O X O X X O X O X X
問題全体には 3 つの異なるパーティションが含まれています -
奇数の場合n は上半分の n-1 ラインを出力し、偶数 n の場合は上半分の n-2 ラインを出力します。
中央の行を印刷します。奇数 n の場合は 1 行、偶数 n の場合は 3 行を印刷します。
下半分を印刷します。奇数 n の場合は n-1 行、偶数 n の場合は n-2 行を印刷します。
アルゴリズム
START STEP 1: IF (n % 2 == 0) then x = x - 1; Define p as n – 1 for spaces Define s = 1 for characters STEP 2: LOOP FOR i= 1 AND i <= (x - 1) / 2 AND i++ LOOP FOR j = 1 AND j <= p AND j++ PRINT SPACE END LOOP IF i % 2 != 0 then GOTO STEP 11 Printx(s) ELSE GOTO STEP 12 Printo(s) END PRINT NEW LINE INCREMENT p BY 1 LOOP FOR j = 1 AND j <= p AND j++ PRINT SPACE END LOOP IF i % 2 != 0 then, GOTO STEP 11 Printx(s) ELSE GOTO STEP 12 Printo(s) END IF PRINT NEWLINE DECREMENT p BY 1 INCREMENT s BY 1 END LOOP STEP 3: IF n % 2 == 0 { LOOP FOR i = 1 AND i <= p AND i++ PRINT SPACE IF n % 4 != 0 then, GOTO STEP 11 Printx(n/2) ELSE GOTO STEP 12 Printo(n/2) END IF PRINT SPACE END IF STEP 4: IF n % 2 != 0 then, GOTO STEP ELSE IF n % 4 != 0 then, DIVIDE n BY 2 AND GOTO STEP 11 Printx(n/2) and Printx(n/2) ELSE DIVIDE n BY 2 AND GOTO STEP 11 Printx(n/2) and Printo(n/2) DIVIDE n BY 2 AND GOTO STEP END IF END IF PRINT NEW LINE STEP 5: IF n % 2 == 0 then, { PRINT SPACE DIVIDE n BY 2 AND GOTO STEP 11 Printx(n/2) PRINT NEWLINE END IF STEP 6: SET p = 1 STEP 7: IF n % 2 == 0 DECREMENT x BY 1 SET p = 2 END IF STEP 8: SET q = x / 2 STEP 9: LOOP FOR i = 1 AND i <= x AND i++) { LOOP FOR j = 1 AND j <= p AND j++ PRINT SPACE END FOR PASS q TO STEP 11 Printx(q) IF i % 2 == 0 THEN DECREMENT q BY 1 END IF PRINT NEWLINE INCREMENT p BY 1 END FOR STEP 10: PRINT NEWLINE STEP 11: Printx(n) LOOP FOR i = 1 AND i< = n AND i++ IF i % 2 != 0 then, PRINT x ELSE PRINT o END IF END FOR STEP 12: Printo(n) LOOP FOR i = 1 AND i< = n AND i++ IF i % 2 != 0 then, PRINT o ELSE PRINT x STOP
例
#include <stdio.h> // printing alternate x o starting with x int printx(int n) { int i; for ( i = 1; i < = n; i++) { if (i % 2! = 0) printf("x "); else printf("o "); } return 0; } // printing alternate x o starting with o int printo(int n) { int i; for ( i = 1; i < = n; i++) { if (i % 2! = 0) printf("o "); else printf("x "); } return 0; } // To print the pattern for n int printpattern(int n) { // upper half // n-1 lines for odd, n-2 lines for even int x = n; int i, j; if (n % 2 == 0) x = x - 1; // number of spaces to leave in each line int p = n - 1; // number of characters in each line int s = 1; // prints double lines in each iteration for ( i = 1; i < = (x - 1) / 2; i++) { for ( j = 1; j < = p; j++) { printf(" "); } if (i % 2! = 0) printx(s); else printo(s); printf("</p><p>"); p++; for ( j = 1; j < = p; j++) printf(" "); if (i % 2! = 0) printx(s); else printo(s); printf("</p><p>"); p--; s++; } // extra upper middle for even if (n % 2 == 0) { for ( i = 1; i < = p; i++) printf(" "); if (n % 4! = 0) printx(n / 2); else printo(n / 2); printf("</p><p>"); } // middle line if (n % 2! = 0) printx(n); else { if (n % 4! = 0) { printx(n / 2); printx(n / 2); } else { printx(n / 2); printo(n / 2); } } printf("</p><p>"); // extra lower middle for even if (n % 2 == 0) { printf(" "); printx(n / 2); printf("</p><p>"); } // lower half p = 1; if (n % 2 == 0) { x--; p = 2; } int q = x / 2; // one line for each iteration for ( i = 1; i < = x; i++) { for (int j = 1; j < = p; j++) printf(" "); printx(q); if (i % 2 == 0) q--; printf("</p><p>"); p++; } printf("</p><p>"); return 1; } int main() { int n = 5; printpattern(n); return 0; }
出力
上記のプログラムを実行すると、次の出力が生成されます。
えええええ以上がC言語で対称二重三角形パターンを印刷するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









C言語データ構造:ツリーとグラフのデータ表現は、ノードからなる階層データ構造です。各ノードには、データ要素と子ノードへのポインターが含まれています。バイナリツリーは特別なタイプの木です。各ノードには、最大2つの子ノードがあります。データは、structreenode {intdata; structreenode*left; structreenode*右;}を表します。操作は、ツリートラバーサルツリー(前向き、順序、および後期)を作成します。検索ツリー挿入ノード削除ノードグラフは、要素が頂点であるデータ構造のコレクションであり、近隣を表す右または未照明のデータを持つエッジを介して接続できます。

ファイルの操作の問題に関する真実:ファイルの開きが失敗しました:不十分な権限、間違ったパス、およびファイルが占有されます。データの書き込みが失敗しました:バッファーがいっぱいで、ファイルは書き込みできず、ディスクスペースが不十分です。その他のFAQ:遅いファイルトラバーサル、誤ったテキストファイルエンコード、およびバイナリファイルの読み取りエラー。

Cのカウントダウンを出力する方法は?回答:ループステートメントを使用します。手順:1。変数nを定義し、カウントダウン数を出力に保存します。 2。whileループを使用して、nが1未満になるまでnを連続的に印刷します。 3。ループ本体で、nの値を印刷します。 4。ループの端で、n x 1を減算して、次の小さな相互に出力します。

C言語マルチスレッドプログラミングガイド:スレッドの作成:pthread_create()関数を使用して、スレッドID、プロパティ、およびスレッド関数を指定します。スレッドの同期:ミューテックス、セマフォ、および条件付き変数を介したデータ競争を防ぎます。実用的なケース:マルチスレッドを使用してフィボナッチ数を計算し、複数のスレッドにタスクを割り当て、結果を同期させます。トラブルシューティング:プログラムのクラッシュ、スレッドの停止応答、パフォーマンスボトルネックなどの問題を解決します。

アルゴリズムは、問題を解決するための一連の指示であり、その実行速度とメモリの使用量はさまざまです。プログラミングでは、多くのアルゴリズムがデータ検索とソートに基づいています。この記事では、いくつかのデータ取得およびソートアルゴリズムを紹介します。線形検索では、配列[20,500,10,5,100,1,50]があることを前提としており、数50を見つける必要があります。線形検索アルゴリズムは、ターゲット値が見つかるまで、または完全な配列が見られるまで配列の各要素を1つずつチェックします。アルゴリズムのフローチャートは次のとおりです。線形検索の擬似コードは次のとおりです。各要素を確認します:ターゲット値が見つかった場合:return true return false c言語実装:#include#includeintmain(void){i

C言語関数は再利用可能なコードブロックです。彼らは入力を受け取り、操作を実行し、結果を返すことができます。これにより、再利用性が改善され、複雑さが軽減されます。関数の内部メカニズムには、パラメーターの渡し、関数の実行、および戻り値が含まれます。プロセス全体には、関数インラインなどの最適化が含まれます。単一の責任、少数のパラメーター、命名仕様、エラー処理の原則に従って、優れた関数が書かれています。関数と組み合わせたポインターは、外部変数値の変更など、より強力な関数を実現できます。関数ポインターは機能をパラメーターまたはストアアドレスとして渡し、機能への動的呼び出しを実装するために使用されます。機能機能とテクニックを理解することは、効率的で保守可能で、理解しやすいCプログラムを書くための鍵です。

C言語処理ファイルのヒントのトラブルシューティングファイルをC言語で処理するとき、さまざまな問題に遭遇する可能性があります。以下は一般的な問題であり、対応するソリューション:問題1:ファイルコードを開くことができません:ファイル*fp = fpen( "myfile.txt"、 "r"); if(fp == null){//ファイルの開く}理由:ファイルパスエラーファイルは存在しません。 Charbuffer [100]; size_tread_bytes = fread(buffer、1、siz

C言語データ構造:人工知能の分野における人工知能におけるデータ構造の重要な役割の概要、データ構造は、大量のデータを処理するために重要です。データ構造は、データを整理および管理し、アルゴリズムを最適化し、プログラムの効率を改善するための効果的な方法を提供します。一般的に使用されるC言語で一般的に使用されるデータ構造には、次のものが含まれます。配列:同じタイプの連続して保存されたデータ項目のセット。構造:さまざまな種類のデータを一緒に整理し、名前を付けるデータ型。リンクリスト:データ項目がポインターによって接続される線形データ構造。スタック:最後のファーストアウト(LIFO)原理に続くデータ構造。キュー:ファーストインファーストアウト(FIFO)原則に続くデータ構造。実用的なケース:グラフ理論の隣接するテーブルは人工知能です
