結果
| 問題 | No.39 桁の数字を入れ替え | 
| コンテスト | |
| ユーザー |  bal4u | 
| 提出日時 | 2019-04-08 12:09:45 | 
| 言語 | C (gcc 13.3.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 1 ms / 5,000 ms | 
| コード長 | 538 bytes | 
| コンパイル時間 | 861 ms | 
| コンパイル使用メモリ | 28,288 KB | 
| 実行使用メモリ | 5,376 KB | 
| 最終ジャッジ日時 | 2024-07-01 22:50:51 | 
| 合計ジャッジ時間 | 957 ms | 
| ジャッジサーバーID (参考情報) | judge1 / judge5 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 19 | 
ソースコード
// yukicoder: No.39 桁の数字を入れ替え
// 2019.4.8 bal4u
// 文字列の入れ替え、ソート
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
char n[15], m[15];
int cmp(const void *a, const void *b) { return *(char *)b - *(char *)a; }
int main()
{
	int i, w;
	char *p;
	scanf("%s", n);
	w = strlen(n);
	memcpy(m, n, w);
	qsort(m, w, sizeof(char), cmp);
	for (i = 0; i < w; i++) {
		if (m[i] != n[i]) {
			p = n + w - 1; while (*p != m[i]) p--;
			*p = n[i], n[i] = m[i];
			break;
		}
	}
	puts(n);
	return 0;
}
            
            
            
        