Diff
checker
텍스트
텍스트
이미지
문서
Excel
폴더
Legal
Enterprise
데스크톱
요금제
로그인
데스크톱 앱 다운로드
텍스트 비교
두 텍스트 파일의 차이점을 찾아보세요
도구
기록
실시간 편집
변경 없는 행 숨기기
줄바꿈 비활성화
레이아웃
나란히 보기
합쳐 보기
비교 단위
스마트
단어
글자
구문 강조
언어 선택
제외
텍스트 변환
첫 변경으로
수정
Diffchecker Desktop
가장 안전하게 Diffchecker를 사용하는 방법. 데스크톱 앱을 사용하면 비교 데이터가 외부로 전송되지 않습니다!
데스크톱 앱 받기
cf diff
생성일
2년 전
비교 결과 만료 없음
초기화
내보내기
공유
설명
1 삭제
행
총
삭제
글자
총
삭제
이 기능을 계속 사용하려면 업그레이드해 주세요
Diff
checker
Pro
요금제 보기
68 행
복사
7 추가
행
총
추가
글자
총
추가
이 기능을 계속 사용하려면 업그레이드해 주세요
Diff
checker
Pro
요금제 보기
74 행
복사
#include <iostream>
#include <iostream>
#include <vector>
#include <vector>
#define int long long
#define int long long
int gcd(int a, int b) {
int gcd(int a, int b) {
if (b == 0) return a;
if (b == 0) return a;
return gcd(b, a % b);
return gcd(b, a % b);
}
}
복사
복사됨
복사
복사됨
std::vector<std::vector<bool>> isposs;
bool isPoss(int value, std::vector<std::vector<int>> &grid) {
bool isPoss(int value, std::vector<std::vector<int>> &grid) {
int n = grid.size(), m = grid[0].size();
int n = grid.size(), m = grid[0].size();
복사
복사됨
복사
복사됨
std::vector<std::vector<bool>> isposs(n, std::vector<bool>(m, 0));
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
isposs[i][j] = 0;
}
}
isposs[0][0] = 1;
isposs[0][0] = 1;
for (int i = 1; i < m; i++) {
for (int i = 1; i < m; i++) {
if (grid[0][i] % value == 0 && isposs[0][i - 1]) isposs[0][i] = 1;
if (grid[0][i] % value == 0 && isposs[0][i - 1]) isposs[0][i] = 1;
}
}
for (int i = 1; i < n; i++) {
for (int i = 1; i < n; i++) {
if (grid[i][0] % value == 0 && isposs[i - 1][0]) isposs[i][0] = 1;
if (grid[i][0] % value == 0 && isposs[i - 1][0]) isposs[i][0] = 1;
}
}
for (int i = 1; i < n; i++) {
for (int i = 1; i < n; i++) {
for (int j = 1; j < m; j++) {
for (int j = 1; j < m; j++) {
if (grid[i][j] % value == 0 &&
if (grid[i][j] % value == 0 &&
(isposs[i][j - 1] || isposs[i - 1][j]))
(isposs[i][j - 1] || isposs[i - 1][j]))
isposs[i][j] = 1;
isposs[i][j] = 1;
}
}
}
}
return isposs[n - 1][m - 1];
return isposs[n - 1][m - 1];
}
}
void solve() {
void solve() {
int n, m;
int n, m;
std::cin >> n >> m;
std::cin >> n >> m;
복사
복사됨
복사
복사됨
isposs.resize(n, std::vector<bool>(m));
std::vector<std::vector<int>> grid(n, std::vector<int>(m));
std::vector<std::vector<int>> grid(n, std::vector<int>(m));
for (int i = 0; i < n; i++) {
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
for (int j = 0; j < m; j++) {
std::cin >> grid[i][j];
std::cin >> grid[i][j];
}
}
}
}
int res = gcd(grid[0][0], grid[n - 1][m - 1]);
int res = gcd(grid[0][0], grid[n - 1][m - 1]);
int ans = 1;
int ans = 1;
for (int i = 1; i * i <= res; i++) {
for (int i = 1; i * i <= res; i++) {
if (res % i) continue;
if (res % i) continue;
int div = res / i;
int div = res / i;
if (isPoss(div, grid)) {
if (isPoss(div, grid)) {
std::cout << div << "\n";
std::cout << div << "\n";
return;
return;
}
}
if (i != 1 && isPoss(i, grid)) ans = i;
if (i != 1 && isPoss(i, grid)) ans = i;
}
}
std::cout << ans << "\n";
std::cout << ans << "\n";
}
}
signed main() {
signed main() {
std::ios::sync_with_stdio(false);
std::ios::sync_with_stdio(false);
std::cin.tie(0);
std::cin.tie(0);
std::cout.tie(0);
std::cout.tie(0);
int t;
int t;
std::cin >> t;
std::cin >> t;
while (t--) {
while (t--) {
solve();
solve();
}
}
return 0;
return 0;
}
}
저장된 비교 결과
원본
파일 열기
#include <iostream> #include <vector> #define int long long int gcd(int a, int b) { if (b == 0) return a; return gcd(b, a % b); } bool isPoss(int value, std::vector<std::vector<int>> &grid) { int n = grid.size(), m = grid[0].size(); std::vector<std::vector<bool>> isposs(n, std::vector<bool>(m, 0)); isposs[0][0] = 1; for (int i = 1; i < m; i++) { if (grid[0][i] % value == 0 && isposs[0][i - 1]) isposs[0][i] = 1; } for (int i = 1; i < n; i++) { if (grid[i][0] % value == 0 && isposs[i - 1][0]) isposs[i][0] = 1; } for (int i = 1; i < n; i++) { for (int j = 1; j < m; j++) { if (grid[i][j] % value == 0 && (isposs[i][j - 1] || isposs[i - 1][j])) isposs[i][j] = 1; } } return isposs[n - 1][m - 1]; } void solve() { int n, m; std::cin >> n >> m; std::vector<std::vector<int>> grid(n, std::vector<int>(m)); for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { std::cin >> grid[i][j]; } } int res = gcd(grid[0][0], grid[n - 1][m - 1]); int ans = 1; for (int i = 1; i * i <= res; i++) { if (res % i) continue; int div = res / i; if (isPoss(div, grid)) { std::cout << div << "\n"; return; } if (i != 1 && isPoss(i, grid)) ans = i; } std::cout << ans << "\n"; } signed main() { std::ios::sync_with_stdio(false); std::cin.tie(0); std::cout.tie(0); int t; std::cin >> t; while (t--) { solve(); } return 0; }
수정본
파일 열기
#include <iostream> #include <vector> #define int long long int gcd(int a, int b) { if (b == 0) return a; return gcd(b, a % b); } std::vector<std::vector<bool>> isposs; bool isPoss(int value, std::vector<std::vector<int>> &grid) { int n = grid.size(), m = grid[0].size(); for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { isposs[i][j] = 0; } } isposs[0][0] = 1; for (int i = 1; i < m; i++) { if (grid[0][i] % value == 0 && isposs[0][i - 1]) isposs[0][i] = 1; } for (int i = 1; i < n; i++) { if (grid[i][0] % value == 0 && isposs[i - 1][0]) isposs[i][0] = 1; } for (int i = 1; i < n; i++) { for (int j = 1; j < m; j++) { if (grid[i][j] % value == 0 && (isposs[i][j - 1] || isposs[i - 1][j])) isposs[i][j] = 1; } } return isposs[n - 1][m - 1]; } void solve() { int n, m; std::cin >> n >> m; isposs.resize(n, std::vector<bool>(m)); std::vector<std::vector<int>> grid(n, std::vector<int>(m)); for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { std::cin >> grid[i][j]; } } int res = gcd(grid[0][0], grid[n - 1][m - 1]); int ans = 1; for (int i = 1; i * i <= res; i++) { if (res % i) continue; int div = res / i; if (isPoss(div, grid)) { std::cout << div << "\n"; return; } if (i != 1 && isPoss(i, grid)) ans = i; } std::cout << ans << "\n"; } signed main() { std::ios::sync_with_stdio(false); std::cin.tie(0); std::cout.tie(0); int t; std::cin >> t; while (t--) { solve(); } return 0; }
비교하기